@agentuity/runtime 0.0.6

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.
Files changed (72) hide show
  1. package/AGENTS.md +128 -0
  2. package/README.md +221 -0
  3. package/dist/_config.d.ts +61 -0
  4. package/dist/_config.d.ts.map +1 -0
  5. package/dist/_context.d.ts +33 -0
  6. package/dist/_context.d.ts.map +1 -0
  7. package/dist/_idle.d.ts +7 -0
  8. package/dist/_idle.d.ts.map +1 -0
  9. package/dist/_server.d.ts +17 -0
  10. package/dist/_server.d.ts.map +1 -0
  11. package/dist/_services.d.ts +2 -0
  12. package/dist/_services.d.ts.map +1 -0
  13. package/dist/_util.d.ts +16 -0
  14. package/dist/_util.d.ts.map +1 -0
  15. package/dist/_waituntil.d.ts +20 -0
  16. package/dist/_waituntil.d.ts.map +1 -0
  17. package/dist/agent.d.ts +88 -0
  18. package/dist/agent.d.ts.map +1 -0
  19. package/dist/app.d.ts +24 -0
  20. package/dist/app.d.ts.map +1 -0
  21. package/dist/index.d.ts +6 -0
  22. package/dist/index.d.ts.map +1 -0
  23. package/dist/logger/console.d.ts +50 -0
  24. package/dist/logger/console.d.ts.map +1 -0
  25. package/dist/logger/index.d.ts +4 -0
  26. package/dist/logger/index.d.ts.map +1 -0
  27. package/dist/logger/internal.d.ts +79 -0
  28. package/dist/logger/internal.d.ts.map +1 -0
  29. package/dist/logger/logger.d.ts +41 -0
  30. package/dist/logger/logger.d.ts.map +1 -0
  31. package/dist/logger/user.d.ts +8 -0
  32. package/dist/logger/user.d.ts.map +1 -0
  33. package/dist/logger/util.d.ts +11 -0
  34. package/dist/logger/util.d.ts.map +1 -0
  35. package/dist/otel/config.d.ts +17 -0
  36. package/dist/otel/config.d.ts.map +1 -0
  37. package/dist/otel/console.d.ts +26 -0
  38. package/dist/otel/console.d.ts.map +1 -0
  39. package/dist/otel/fetch.d.ts +12 -0
  40. package/dist/otel/fetch.d.ts.map +1 -0
  41. package/dist/otel/http.d.ts +16 -0
  42. package/dist/otel/http.d.ts.map +1 -0
  43. package/dist/otel/logger.d.ts +36 -0
  44. package/dist/otel/logger.d.ts.map +1 -0
  45. package/dist/otel/otel.d.ts +58 -0
  46. package/dist/otel/otel.d.ts.map +1 -0
  47. package/dist/router.d.ts +37 -0
  48. package/dist/router.d.ts.map +1 -0
  49. package/package.json +58 -0
  50. package/src/_config.ts +101 -0
  51. package/src/_context.ts +86 -0
  52. package/src/_idle.ts +26 -0
  53. package/src/_server.ts +279 -0
  54. package/src/_services.ts +164 -0
  55. package/src/_util.ts +63 -0
  56. package/src/_waituntil.ts +246 -0
  57. package/src/agent.ts +287 -0
  58. package/src/app.ts +31 -0
  59. package/src/index.ts +5 -0
  60. package/src/logger/console.ts +111 -0
  61. package/src/logger/index.ts +3 -0
  62. package/src/logger/internal.ts +165 -0
  63. package/src/logger/logger.ts +44 -0
  64. package/src/logger/user.ts +11 -0
  65. package/src/logger/util.ts +80 -0
  66. package/src/otel/config.ts +81 -0
  67. package/src/otel/console.ts +56 -0
  68. package/src/otel/fetch.ts +103 -0
  69. package/src/otel/http.ts +51 -0
  70. package/src/otel/logger.ts +238 -0
  71. package/src/otel/otel.ts +317 -0
  72. package/src/router.ts +302 -0
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,SAAS,CAAC;AACxB,cAAc,OAAO,CAAC;AACtB,cAAc,UAAU,CAAC;AACzB,YAAY,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AACvC,OAAO,EAAE,MAAM,EAAE,MAAM,WAAW,CAAC"}
@@ -0,0 +1,50 @@
1
+ import type { Logger } from './logger';
2
+ /**
3
+ * Console implementation of the Logger interface
4
+ */
5
+ export default class ConsoleLogger implements Logger {
6
+ private context;
7
+ private formatContext;
8
+ /**
9
+ * Creates a new console logger
10
+ *
11
+ * @param context - Initial context for the logger
12
+ */
13
+ constructor(context?: Record<string, unknown>, formatContext?: boolean);
14
+ /**
15
+ * Log a debug message
16
+ *
17
+ * @param message - The message to log
18
+ * @param args - Additional arguments to log
19
+ */
20
+ debug(message: unknown, ...args: unknown[]): void;
21
+ /**
22
+ * Log an info message
23
+ *
24
+ * @param message - The message to log
25
+ * @param args - Additional arguments to log
26
+ */
27
+ info(message: unknown, ...args: unknown[]): void;
28
+ /**
29
+ * Log a warning message
30
+ *
31
+ * @param message - The message to log
32
+ * @param args - Additional arguments to log
33
+ */
34
+ warn(message: unknown, ...args: unknown[]): void;
35
+ /**
36
+ * Log an error message
37
+ *
38
+ * @param message - The message to log
39
+ * @param args - Additional arguments to log
40
+ */
41
+ error(message: unknown, ...args: unknown[]): void;
42
+ /**
43
+ * Create a child logger with additional context
44
+ *
45
+ * @param opts - Additional context for the child logger
46
+ * @returns A new logger instance with the additional context
47
+ */
48
+ child(opts: Record<string, unknown>): Logger;
49
+ }
50
+ //# sourceMappingURL=console.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"console.d.ts","sourceRoot":"","sources":["../../src/logger/console.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AASvC;;GAEG;AACH,MAAM,CAAC,OAAO,OAAO,aAAc,YAAW,MAAM;IACnD,OAAO,CAAC,OAAO,CAA0B;IACzC,OAAO,CAAC,aAAa,CAAU;IAE/B;;;;OAIG;gBACS,OAAO,GAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAM,EAAE,aAAa,UAAO;IAKvE;;;;;OAKG;IACH,KAAK,CAAC,OAAO,EAAE,OAAO,EAAE,GAAG,IAAI,EAAE,OAAO,EAAE,GAAG,IAAI;IAWjD;;;;;OAKG;IACH,IAAI,CAAC,OAAO,EAAE,OAAO,EAAE,GAAG,IAAI,EAAE,OAAO,EAAE,GAAG,IAAI;IAWhD;;;;;OAKG;IACH,IAAI,CAAC,OAAO,EAAE,OAAO,EAAE,GAAG,IAAI,EAAE,OAAO,EAAE,GAAG,IAAI;IAWhD;;;;;OAKG;IACH,KAAK,CAAC,OAAO,EAAE,OAAO,EAAE,GAAG,IAAI,EAAE,OAAO,EAAE,GAAG,IAAI;IAWjD;;;;;OAKG;IACH,KAAK,CAAC,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,MAAM;CAS5C"}
@@ -0,0 +1,4 @@
1
+ export { internal } from './internal';
2
+ export * from './logger';
3
+ export { type Logger, logger } from './user';
4
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/logger/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AACtC,cAAc,UAAU,CAAC;AACzB,OAAO,EAAE,KAAK,MAAM,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC"}
@@ -0,0 +1,79 @@
1
+ /**
2
+ * Log levels for internal SDK logging
3
+ */
4
+ export type LogLevel = 'debug' | 'info' | 'warn' | 'error' | 'silent';
5
+ /**
6
+ * Internal logger configuration
7
+ */
8
+ interface InternalLoggerConfig {
9
+ level: LogLevel;
10
+ context?: Record<string, unknown>;
11
+ }
12
+ /**
13
+ * Simple internal logger that doesn't depend on other SDK modules
14
+ * This logger is only for SDK internal diagnostics and debugging
15
+ */
16
+ declare class InternalLogger {
17
+ private config;
18
+ constructor();
19
+ /**
20
+ * Load configuration from environment variables
21
+ */
22
+ private loadConfig;
23
+ /**
24
+ * Check if a log level should be output based on current configuration
25
+ */
26
+ private shouldLog;
27
+ /**
28
+ * Format a log message with context
29
+ */
30
+ private formatMessage;
31
+ /**
32
+ * Log a debug message
33
+ */
34
+ debug(message: unknown, ...args: unknown[]): void;
35
+ /**
36
+ * Log an info message
37
+ */
38
+ info(message: unknown, ...args: unknown[]): void;
39
+ /**
40
+ * Log a warning message
41
+ */
42
+ warn(message: unknown, ...args: unknown[]): void;
43
+ /**
44
+ * Log an error message
45
+ */
46
+ error(message: unknown, ...args: unknown[]): void;
47
+ /**
48
+ * Update configuration at runtime
49
+ */
50
+ updateConfig(config: Partial<InternalLoggerConfig>): void;
51
+ /**
52
+ * Get current configuration
53
+ */
54
+ getConfig(): InternalLoggerConfig;
55
+ /**
56
+ * Check if logging is enabled
57
+ */
58
+ isEnabled(): boolean;
59
+ /**
60
+ * Create a child logger with additional context
61
+ */
62
+ child(context: Record<string, unknown>): InternalLogger;
63
+ }
64
+ /**
65
+ * Internal logger for SDK use only
66
+ * This is NOT exported from the main SDK index
67
+ */
68
+ export declare const internal: {
69
+ debug: (message: unknown, ...args: unknown[]) => void;
70
+ info: (message: unknown, ...args: unknown[]) => void;
71
+ warn: (message: unknown, ...args: unknown[]) => void;
72
+ error: (message: unknown, ...args: unknown[]) => void;
73
+ updateConfig: (config: Partial<InternalLoggerConfig>) => void;
74
+ getConfig: () => InternalLoggerConfig;
75
+ isEnabled: () => boolean;
76
+ child: (context: Record<string, unknown>) => InternalLogger;
77
+ };
78
+ export {};
79
+ //# sourceMappingURL=internal.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"internal.d.ts","sourceRoot":"","sources":["../../src/logger/internal.ts"],"names":[],"mappings":"AAKA;;GAEG;AACH,MAAM,MAAM,QAAQ,GAAG,OAAO,GAAG,MAAM,GAAG,MAAM,GAAG,OAAO,GAAG,QAAQ,CAAC;AAEtE;;GAEG;AACH,UAAU,oBAAoB;IAC7B,KAAK,EAAE,QAAQ,CAAC;IAChB,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CAClC;AAED;;;GAGG;AACH,cAAM,cAAc;IACnB,OAAO,CAAC,MAAM,CAAuB;;IAMrC;;OAEG;IACH,OAAO,CAAC,UAAU;IAgBlB;;OAEG;IACH,OAAO,CAAC,SAAS;IAcjB;;OAEG;IACH,OAAO,CAAC,aAAa;IAKrB;;OAEG;IACH,KAAK,CAAC,OAAO,EAAE,OAAO,EAAE,GAAG,IAAI,EAAE,OAAO,EAAE,GAAG,IAAI;IAMjD;;OAEG;IACH,IAAI,CAAC,OAAO,EAAE,OAAO,EAAE,GAAG,IAAI,EAAE,OAAO,EAAE,GAAG,IAAI;IAMhD;;OAEG;IACH,IAAI,CAAC,OAAO,EAAE,OAAO,EAAE,GAAG,IAAI,EAAE,OAAO,EAAE,GAAG,IAAI;IAMhD;;OAEG;IACH,KAAK,CAAC,OAAO,EAAE,OAAO,EAAE,GAAG,IAAI,EAAE,OAAO,EAAE,GAAG,IAAI;IAMjD;;OAEG;IACH,YAAY,CAAC,MAAM,EAAE,OAAO,CAAC,oBAAoB,CAAC,GAAG,IAAI;IAIzD;;OAEG;IACH,SAAS,IAAI,oBAAoB;IAIjC;;OAEG;IACH,SAAS,IAAI,OAAO;IAIpB;;OAEG;IACH,KAAK,CAAC,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,cAAc;CAWvD;AAKD;;;GAGG;AACH,eAAO,MAAM,QAAQ;qBACH,OAAO,WAAW,OAAO,EAAE;oBAC5B,OAAO,WAAW,OAAO,EAAE;oBAC3B,OAAO,WAAW,OAAO,EAAE;qBAC1B,OAAO,WAAW,OAAO,EAAE;2BAGrB,OAAO,CAAC,oBAAoB,CAAC;;;qBAGnC,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;CACxC,CAAC"}
@@ -0,0 +1,41 @@
1
+ /**
2
+ * Interface for logging functionality
3
+ */
4
+ export interface Logger {
5
+ /**
6
+ * Log a debug message
7
+ *
8
+ * @param message - The message to log
9
+ * @param args - Additional arguments to log
10
+ */
11
+ debug(message: unknown, ...args: unknown[]): void;
12
+ /**
13
+ * Log an info message
14
+ *
15
+ * @param message - The message to log
16
+ * @param args - Additional arguments to log
17
+ */
18
+ info(message: unknown, ...args: unknown[]): void;
19
+ /**
20
+ * Log a warning message
21
+ *
22
+ * @param message - The message to log
23
+ * @param args - Additional arguments to log
24
+ */
25
+ warn(message: unknown, ...args: unknown[]): void;
26
+ /**
27
+ * Log an error message
28
+ *
29
+ * @param message - The message to log
30
+ * @param args - Additional arguments to log
31
+ */
32
+ error(message: unknown, ...args: unknown[]): void;
33
+ /**
34
+ * Create a child logger with additional context
35
+ *
36
+ * @param opts - Additional context for the child logger
37
+ * @returns A new logger instance with the additional context
38
+ */
39
+ child(opts: Record<string, unknown>): Logger;
40
+ }
41
+ //# sourceMappingURL=logger.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logger.d.ts","sourceRoot":"","sources":["../../src/logger/logger.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,MAAM,WAAW,MAAM;IACtB;;;;;OAKG;IACH,KAAK,CAAC,OAAO,EAAE,OAAO,EAAE,GAAG,IAAI,EAAE,OAAO,EAAE,GAAG,IAAI,CAAC;IAElD;;;;;OAKG;IACH,IAAI,CAAC,OAAO,EAAE,OAAO,EAAE,GAAG,IAAI,EAAE,OAAO,EAAE,GAAG,IAAI,CAAC;IAEjD;;;;;OAKG;IACH,IAAI,CAAC,OAAO,EAAE,OAAO,EAAE,GAAG,IAAI,EAAE,OAAO,EAAE,GAAG,IAAI,CAAC;IAEjD;;;;;OAKG;IACH,KAAK,CAAC,OAAO,EAAE,OAAO,EAAE,GAAG,IAAI,EAAE,OAAO,EAAE,GAAG,IAAI,CAAC;IAElD;;;;;OAKG;IACH,KAAK,CAAC,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,MAAM,CAAC;CAC7C"}
@@ -0,0 +1,8 @@
1
+ import type { Logger } from './logger';
2
+ /**
3
+ * User-facing logger instance
4
+ * This is the logger that SDK consumers should use
5
+ */
6
+ export declare const logger: Logger;
7
+ export type { Logger } from './logger';
8
+ //# sourceMappingURL=user.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"user.d.ts","sourceRoot":"","sources":["../../src/logger/user.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAEvC;;;GAGG;AACH,eAAO,MAAM,MAAM,EAAE,MAA4C,CAAC;AAGlE,YAAY,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC"}
@@ -0,0 +1,11 @@
1
+ export declare function buildContextString(context?: Record<string, unknown>): string;
2
+ /**
3
+ * Formats a log message with context
4
+ *
5
+ * @param message - The message to format
6
+ * @param args - Additional arguments for formatting
7
+ * @returns The formatted message with context
8
+ * @private
9
+ */
10
+ export declare function formatMessage(displayContext: boolean, context: Record<string, unknown> | undefined, message: unknown, args: unknown[]): string;
11
+ //# sourceMappingURL=util.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"util.d.ts","sourceRoot":"","sources":["../../src/logger/util.ts"],"names":[],"mappings":"AAGA,wBAAgB,kBAAkB,CAAC,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,MAAM,CAkB5E;AAED;;;;;;;GAOG;AACH,wBAAgB,aAAa,CAC5B,cAAc,EAAE,OAAO,EACvB,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,SAAS,EAC5C,OAAO,EAAE,OAAO,EAChB,IAAI,EAAE,OAAO,EAAE,GACb,MAAM,CA2CR"}
@@ -0,0 +1,17 @@
1
+ import type { OtelResponse } from './otel';
2
+ import type { SpanProcessor } from '@opentelemetry/sdk-trace-base';
3
+ /**
4
+ * Configuration for user provided OpenTelemetry
5
+ */
6
+ export interface CustomizedOtelConfig {
7
+ endpoint: string;
8
+ serviceName: string;
9
+ resourceAttributes: Record<string, string>;
10
+ headers: Record<string, string>;
11
+ }
12
+ interface OtelRegisterConfig {
13
+ processors?: SpanProcessor[];
14
+ }
15
+ export declare function register(registerConfig: OtelRegisterConfig): OtelResponse;
16
+ export {};
17
+ //# sourceMappingURL=config.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"config.d.ts","sourceRoot":"","sources":["../../src/otel/config.ts"],"names":[],"mappings":"AAOA,OAAO,KAAK,EAAE,YAAY,EAAc,MAAM,QAAQ,CAAC;AACvD,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,+BAA+B,CAAC;AAGnE;;GAEG;AACH,MAAM,WAAW,oBAAoB;IACpC,QAAQ,EAAE,MAAM,CAAC;IAGjB,WAAW,EAAE,MAAM,CAAC;IACpB,kBAAkB,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAC3C,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;CAChC;AAED,UAAU,kBAAkB;IAC3B,UAAU,CAAC,EAAE,aAAa,EAAE,CAAC;CAC7B;AAED,wBAAgB,QAAQ,CAAC,cAAc,EAAE,kBAAkB,GAAG,YAAY,CAqDzE"}
@@ -0,0 +1,26 @@
1
+ import { type ExportResult } from '@opentelemetry/core';
2
+ import type { LogRecordExporter, ReadableLogRecord } from '@opentelemetry/sdk-logs';
3
+ /**
4
+ * Console implementation of the LogRecordExporter interface
5
+ */
6
+ export declare class ConsoleLogRecordExporter implements LogRecordExporter {
7
+ private readonly logger;
8
+ /**
9
+ * Creates a new console log record exporter
10
+ */
11
+ constructor();
12
+ /**
13
+ * Exports log records to the console
14
+ *
15
+ * @param logs - The log records to export
16
+ * @param resultCallback - Callback function to report the export result
17
+ */
18
+ export(logs: ReadableLogRecord[], resultCallback: (result: ExportResult) => void): void;
19
+ /**
20
+ * Shuts down the exporter
21
+ *
22
+ * @returns A promise that resolves when shutdown is complete
23
+ */
24
+ shutdown(): Promise<void>;
25
+ }
26
+ //# sourceMappingURL=console.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"console.d.ts","sourceRoot":"","sources":["../../src/otel/console.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,KAAK,YAAY,EAAoB,MAAM,qBAAqB,CAAC;AAC1E,OAAO,KAAK,EAAE,iBAAiB,EAAE,iBAAiB,EAAE,MAAM,yBAAyB,CAAC;AAGpF;;GAEG;AACH,qBAAa,wBAAyB,YAAW,iBAAiB;IACjE,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAgB;IAEvC;;OAEG;;IAKH;;;;;OAKG;IACH,MAAM,CAAC,IAAI,EAAE,iBAAiB,EAAE,EAAE,cAAc,EAAE,CAAC,MAAM,EAAE,YAAY,KAAK,IAAI,GAAG,IAAI;IAuBvF;;;;OAIG;IACH,QAAQ,IAAI,OAAO,CAAC,IAAI,CAAC;CAGzB"}
@@ -0,0 +1,12 @@
1
+ /**
2
+ * Reference to the original fetch function before instrumentation
3
+ */
4
+ export declare const __originalFetch: typeof fetch;
5
+ /**
6
+ * Instruments the global fetch function with OpenTelemetry tracing
7
+ *
8
+ * Replaces the global fetch with an instrumented version that creates spans
9
+ * for each HTTP request and propagates trace context in headers
10
+ */
11
+ export declare function instrumentFetch(): void;
12
+ //# sourceMappingURL=fetch.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"fetch.d.ts","sourceRoot":"","sources":["../../src/otel/fetch.ts"],"names":[],"mappings":"AAEA;;GAEG;AACH,eAAO,MAAM,eAAe,cAAQ,CAAC;AAErC;;;;;GAKG;AACH,wBAAgB,eAAe,SAyF9B"}
@@ -0,0 +1,16 @@
1
+ import { propagation } from '@opentelemetry/api';
2
+ /**
3
+ * Injects trace context into response headers using the OpenTelemetry propagation API
4
+ *
5
+ * @param headers - Optional existing headers to include
6
+ * @returns A record of headers with trace context injected
7
+ */
8
+ export declare function injectTraceContextToHeaders(headers?: Record<string, string> | Headers): Record<string, string>;
9
+ /**
10
+ * Extracts trace context from Bun Request headers
11
+ *
12
+ * @param req - The Bun Request object
13
+ * @returns The context with trace information
14
+ */
15
+ export declare function extractTraceContextFromRequest(req: Request): ReturnType<typeof propagation.extract>;
16
+ //# sourceMappingURL=http.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"http.d.ts","sourceRoot":"","sources":["../../src/otel/http.ts"],"names":[],"mappings":"AAAA,OAAO,EAAW,WAAW,EAAE,MAAM,oBAAoB,CAAC;AAE1D;;;;;GAKG;AACH,wBAAgB,2BAA2B,CAC1C,OAAO,GAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,GAAG,OAAY,GAC5C,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAkBxB;AAED;;;;;GAKG;AACH,wBAAgB,8BAA8B,CAC7C,GAAG,EAAE,OAAO,GACV,UAAU,CAAC,OAAO,WAAW,CAAC,OAAO,CAAC,CAYxC"}
@@ -0,0 +1,36 @@
1
+ import * as LogsAPI from '@opentelemetry/api-logs';
2
+ import type { Logger } from '../logger';
3
+ /**
4
+ * Reference to the original console object before patching
5
+ */
6
+ export declare const __originalConsole: any;
7
+ export declare class OtelLogger implements Logger {
8
+ private readonly delegates;
9
+ private readonly context;
10
+ private readonly logger;
11
+ constructor(useConsole: boolean, delegates: LogsAPI.Logger | LogsAPI.Logger[], context?: Record<string, unknown> | undefined);
12
+ addDelegate(delegate: LogsAPI.Logger): void;
13
+ private formatMessage;
14
+ private getAttributes;
15
+ private emitToAll;
16
+ debug(message: string, ...args: unknown[]): void;
17
+ info(message: string, ...args: unknown[]): void;
18
+ warn(message: string, ...args: unknown[]): void;
19
+ error(message: string, ...args: unknown[]): void;
20
+ child(opts: Record<string, unknown>): OtelLogger;
21
+ }
22
+ /**
23
+ * Creates a logger that integrates with OpenTelemetry
24
+ *
25
+ * @param useConsole - Whether to also log to the console
26
+ * @param context - Additional context to include with log records
27
+ * @returns A logger instance
28
+ */
29
+ export declare function createLogger(useConsole: boolean, context?: Record<string, unknown>): Logger;
30
+ /**
31
+ * Patches the global console object to integrate with OpenTelemetry logging
32
+ *
33
+ * @param attributes - Attributes to include with all console log records
34
+ */
35
+ export declare function patchConsole(enabled: boolean, attributes: Record<string, unknown>): void;
36
+ //# sourceMappingURL=logger.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logger.d.ts","sourceRoot":"","sources":["../../src/otel/logger.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,OAAO,MAAM,yBAAyB,CAAC;AACnD,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,WAAW,CAAC;AAIxC;;GAEG;AACH,eAAO,MAAM,iBAAiB,KAAyB,CAAC;AAExD,qBAAa,UAAW,YAAW,MAAM;IACxC,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAmB;IAC7C,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAsC;IAC9D,OAAO,CAAC,QAAQ,CAAC,MAAM,CAA4B;gBAGlD,UAAU,EAAE,OAAO,EACnB,SAAS,EAAE,OAAO,CAAC,MAAM,GAAG,OAAO,CAAC,MAAM,EAAE,EAC5C,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,SAAS;IAO9C,WAAW,CAAC,QAAQ,EAAE,OAAO,CAAC,MAAM;IAIpC,OAAO,CAAC,aAAa;IAYrB,OAAO,CAAC,aAAa;IAqBrB,OAAO,CAAC,SAAS;IAkBjB,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,GAAG,IAAI,EAAE,OAAO,EAAE;IAWzC,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,GAAG,IAAI,EAAE,OAAO,EAAE;IAWxC,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,GAAG,IAAI,EAAE,OAAO,EAAE;IAWxC,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,GAAG,IAAI,EAAE,OAAO,EAAE;IAWzC,KAAK,CAAC,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;CAMnC;AAED;;;;;;GAMG;AACH,wBAAgB,YAAY,CAAC,UAAU,EAAE,OAAO,EAAE,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,MAAM,CAK3F;AAED;;;;GAIG;AACH,wBAAgB,YAAY,CAAC,OAAO,EAAE,OAAO,EAAE,UAAU,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,QAoFjF"}
@@ -0,0 +1,58 @@
1
+ import type { SpanProcessor } from '@opentelemetry/sdk-trace-base';
2
+ import { type Meter, type Tracer } from '@opentelemetry/api';
3
+ import { OTLPLogExporter } from '@opentelemetry/exporter-logs-otlp-http';
4
+ import type { Resource } from '@opentelemetry/resources';
5
+ import { BatchLogRecordProcessor, LoggerProvider, type LogRecordProcessor } from '@opentelemetry/sdk-logs';
6
+ import type { Logger } from '../logger';
7
+ /**
8
+ * Configuration for OpenTelemetry initialization
9
+ */
10
+ export interface OtelConfig {
11
+ url?: string;
12
+ name: string;
13
+ version: string;
14
+ bearerToken?: string;
15
+ orgId?: string;
16
+ projectId?: string;
17
+ deploymentId?: string;
18
+ environment?: string;
19
+ cliVersion?: string;
20
+ devmode?: boolean;
21
+ spanProcessors?: Array<SpanProcessor>;
22
+ }
23
+ /**
24
+ * Response from OpenTelemetry initialization
25
+ */
26
+ export interface OtelResponse {
27
+ tracer: Tracer;
28
+ meter: Meter;
29
+ logger: Logger;
30
+ shutdown: () => Promise<void>;
31
+ }
32
+ export declare const createResource: (config: OtelConfig) => Resource;
33
+ export declare const createAgentuityLoggerProvider: ({ url, headers, resource, }: {
34
+ url?: string;
35
+ headers?: Record<string, string>;
36
+ resource: Resource;
37
+ }) => {
38
+ processor: LogRecordProcessor;
39
+ provider: LoggerProvider;
40
+ exporter: OTLPLogExporter | undefined;
41
+ };
42
+ export declare const createUserLoggerProvider: ({ url, headers, resource, }: {
43
+ url: string;
44
+ headers?: Record<string, string>;
45
+ resource: Resource;
46
+ }) => {
47
+ provider: LoggerProvider;
48
+ exporter: OTLPLogExporter;
49
+ processor: BatchLogRecordProcessor;
50
+ };
51
+ /**
52
+ * Registers and initializes OpenTelemetry with the specified configuration
53
+ *
54
+ * @param config - The configuration for OpenTelemetry
55
+ * @returns An object containing the tracer, logger, and shutdown function
56
+ */
57
+ export declare function registerOtel(config: OtelConfig): OtelResponse;
58
+ //# sourceMappingURL=otel.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"otel.d.ts","sourceRoot":"","sources":["../../src/otel/otel.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,+BAA+B,CAAC;AACnE,OAAsB,EAAE,KAAK,KAAK,EAAwB,KAAK,MAAM,EAAE,MAAM,oBAAoB,CAAC;AAQlG,OAAO,EAAE,eAAe,EAAE,MAAM,wCAAwC,CAAC;AAMzE,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,0BAA0B,CAAC;AACzD,OAAO,EACN,uBAAuB,EACvB,cAAc,EACd,KAAK,kBAAkB,EAEvB,MAAM,yBAAyB,CAAC;AAKjC,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,WAAW,CAAC;AAMxC;;GAEG;AACH,MAAM,WAAW,UAAU;IAC1B,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,EAAE,MAAM,CAAC;IAChB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,cAAc,CAAC,EAAE,KAAK,CAAC,aAAa,CAAC,CAAC;CACtC;AAED;;GAEG;AACH,MAAM,WAAW,YAAY;IAC5B,MAAM,EAAE,MAAM,CAAC;IACf,KAAK,EAAE,KAAK,CAAC;IACb,MAAM,EAAE,MAAM,CAAC;IACf,QAAQ,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAC;CAC9B;AAKD,eAAO,MAAM,cAAc,GAAI,QAAQ,UAAU,KAAG,QAiBnD,CAAC;AAEF,eAAO,MAAM,6BAA6B,GAAI,6BAI3C;IACF,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACjC,QAAQ,EAAE,QAAQ,CAAC;CACnB;;;;CA0BA,CAAC;AAEF,eAAO,MAAM,wBAAwB,GAAI,6BAItC;IACF,GAAG,EAAE,MAAM,CAAC;IACZ,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACjC,QAAQ,EAAE,QAAQ,CAAC;CACnB;;;;CAiBA,CAAC;AAEF;;;;;GAKG;AACH,wBAAgB,YAAY,CAAC,MAAM,EAAE,UAAU,GAAG,YAAY,CAsK7D"}
@@ -0,0 +1,37 @@
1
+ import { type Context, Hono, type Input, type MiddlewareHandler, type Schema } from 'hono';
2
+ import type { Env } from './app';
3
+ type AgentHandler<E extends Env = Env, P extends string = string, I extends Input = {}> = (c: Context<E, P, I>) => any | Promise<any>;
4
+ type StreamHandler<E extends Env = Env, P extends string = string, I extends Input = {}> = (c: Context<E, P, I>) => ReadableStream<any> | Promise<ReadableStream<any>>;
5
+ interface WebSocketConnection {
6
+ onOpen: (handler: (event: any) => void | Promise<void>) => void;
7
+ onMessage: (handler: (event: any) => void | Promise<void>) => void;
8
+ onClose: (handler: (event: any) => void | Promise<void>) => void;
9
+ send: (data: string | ArrayBuffer | Uint8Array) => void;
10
+ }
11
+ type WebSocketHandler<E extends Env = Env, P extends string = string, I extends Input = {}> = (c: Context<E, P, I>) => (ws: WebSocketConnection) => void | Promise<void>;
12
+ type SSEHandler<E extends Env = Env, P extends string = string, I extends Input = {}> = (c: Context<E, P, I>) => (stream: any) => void | Promise<void>;
13
+ type HttpMethod = 'get' | 'post' | 'put' | 'delete' | 'patch' | 'options';
14
+ type ExtendedHono<E extends Env = Env, S extends Schema = {}> = {
15
+ [K in Exclude<keyof Hono<E, S>, HttpMethod>]: Hono<E, S>[K];
16
+ } & {
17
+ [K in HttpMethod]: {
18
+ <P extends string = string>(path: P, handler: AgentHandler<E, P>): Hono<E, S>;
19
+ <P extends string = string, I extends Input = {}>(path: P, middleware: MiddlewareHandler<E, P, I>, handler: AgentHandler<E, P, I>): Hono<E, S>;
20
+ <P extends string = string, I extends Input = {}>(path: P, middleware: MiddlewareHandler<E, P, I>): Hono<E, S>;
21
+ };
22
+ } & {
23
+ email(address: string, handler: AgentHandler): Hono<E, S>;
24
+ sms(params: {
25
+ number: string;
26
+ }, handler: AgentHandler): Hono<E, S>;
27
+ cron(schedule: string, handler: AgentHandler): Hono<E, S>;
28
+ stream<P extends string = string>(path: P, handler: StreamHandler<E, P>): Hono<E, S>;
29
+ stream<P extends string = string, I extends Input = {}>(path: P, middleware: MiddlewareHandler<E, P, I>, handler: StreamHandler<E, P, I>): Hono<E, S>;
30
+ websocket<P extends string = string>(path: P, handler: WebSocketHandler<E, P>): Hono<E, S>;
31
+ websocket<P extends string = string, I extends Input = {}>(path: P, middleware: MiddlewareHandler<E, P, I>, handler: WebSocketHandler<E, P, I>): Hono<E, S>;
32
+ sse<P extends string = string>(path: P, handler: SSEHandler<E, P>): Hono<E, S>;
33
+ sse<P extends string = string, I extends Input = {}>(path: P, middleware: MiddlewareHandler<E, P, I>, handler: SSEHandler<E, P, I>): Hono<E, S>;
34
+ };
35
+ export declare const createRouter: <E extends Env = Env, S extends Schema = Schema>() => ExtendedHono<E, S>;
36
+ export {};
37
+ //# sourceMappingURL=router.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"router.d.ts","sourceRoot":"","sources":["../src/router.ts"],"names":[],"mappings":"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"}
package/package.json ADDED
@@ -0,0 +1,58 @@
1
+ {
2
+ "name": "@agentuity/runtime",
3
+ "version": "0.0.6",
4
+ "type": "module",
5
+ "main": "./src/index.ts",
6
+ "types": "./dist/index.d.ts",
7
+ "exports": {
8
+ ".": {
9
+ "import": "./src/index.ts",
10
+ "types": "./dist/index.d.ts"
11
+ }
12
+ },
13
+ "files": [
14
+ "AGENTS.md",
15
+ "README.md",
16
+ "src",
17
+ "dist"
18
+ ],
19
+ "scripts": {
20
+ "clean": "rm -rf dist",
21
+ "build": "bunx tsc --build --force",
22
+ "typecheck": "bunx tsc --noEmit",
23
+ "prepublishOnly": "bun run clean && bun run build"
24
+ },
25
+ "dependencies": {
26
+ "@agentuity/core": "0.0.6",
27
+ "@agentuity/server": "0.0.6",
28
+ "@opentelemetry/api": "^1.9.0",
29
+ "@opentelemetry/api-logs": "^0.207.0",
30
+ "@opentelemetry/auto-instrumentations-node": "^0.66.0",
31
+ "@opentelemetry/core": "^2.2.0",
32
+ "@opentelemetry/exporter-logs-otlp-http": "^0.207.0",
33
+ "@opentelemetry/exporter-metrics-otlp-http": "^0.207.0",
34
+ "@opentelemetry/exporter-trace-otlp-http": "^0.207.0",
35
+ "@opentelemetry/host-metrics": "^0.36.2",
36
+ "@opentelemetry/otlp-exporter-base": "^0.207.0",
37
+ "@opentelemetry/resources": "^2.2.0",
38
+ "@opentelemetry/sdk-logs": "^0.207.0",
39
+ "@opentelemetry/sdk-metrics": "^2.2.0",
40
+ "@opentelemetry/sdk-node": "^0.207.0",
41
+ "@opentelemetry/sdk-trace-base": "^2.2.0",
42
+ "@opentelemetry/semantic-conventions": "^1.37.0",
43
+ "@traceloop/node-server-sdk": "^0.19.1"
44
+ },
45
+ "peerDependencies": {
46
+ "hono": "^4.10.3"
47
+ },
48
+ "devDependencies": {
49
+ "@types/react": "^19.2.2",
50
+ "@types/react-dom": "^19.2.2",
51
+ "typescript": "^5.9.0",
52
+ "react": "^19.2.0",
53
+ "react-dom": "^19.2.0"
54
+ },
55
+ "publishConfig": {
56
+ "access": "public"
57
+ }
58
+ }
package/src/_config.ts ADDED
@@ -0,0 +1,101 @@
1
+ let appName: string | undefined;
2
+ let appVersion: string | undefined;
3
+
4
+ (async () => {
5
+ const f = Bun.file('./package.json');
6
+ if (await f.exists()) {
7
+ const pkg = JSON.parse(await f.text());
8
+ appName = pkg.name;
9
+ appVersion = pkg.version;
10
+ }
11
+ })();
12
+
13
+ /**
14
+ * Returns the SDK Version that was used to build this app
15
+ *
16
+ * @returns string
17
+ */
18
+ export function getSDKVersion(): string {
19
+ return process.env.AGENTUITY_CLOUD_SDK_VERSION ?? 'unknown';
20
+ }
21
+
22
+ /**
23
+ * Returns the App Name that was used when this app was built
24
+ *
25
+ * @returns string
26
+ */
27
+ export function getAppName(): string {
28
+ return appName ?? 'unknown';
29
+ }
30
+
31
+ /**
32
+ * Returns the App Version that was used when this app was built
33
+ *
34
+ * @returns string
35
+ */
36
+ export function getAppVersion(): string {
37
+ return appVersion ?? 'unknown';
38
+ }
39
+
40
+ /**
41
+ * Returns the Organization ID for this app
42
+ *
43
+ * @returns string
44
+ */
45
+ export function getOrganizationId(): string | undefined {
46
+ return process.env.AGENTUITY_CLOUD_ORG_ID;
47
+ }
48
+
49
+ /**
50
+ * Returns the Project ID for this app
51
+ *
52
+ * @returns string
53
+ */
54
+ export function getProjectId(): string | undefined {
55
+ return process.env.AGENTUITY_CLOUD_PROJECT_ID;
56
+ }
57
+
58
+ /**
59
+ * Returns the Deployment ID for this app that was deployed
60
+ *
61
+ * @returns string | undefined
62
+ */
63
+ export function getDeploymentId(): string | undefined {
64
+ return process.env.AGENTUITY_CLOUD_DEPLOYMENT_ID;
65
+ }
66
+
67
+ /**
68
+ * Returns true if the app is running in dev mode
69
+ *
70
+ * @returns boolean
71
+ */
72
+ export function isDevMode(): boolean {
73
+ return process.env.AGENTUITY_SDK_DEV_MODE === 'true';
74
+ }
75
+
76
+ /**
77
+ * Returns true if the app is running in production mode
78
+ *
79
+ * @returns boolean
80
+ */
81
+ export function isProduction(): boolean {
82
+ return process.env.NODE_ENV === 'production';
83
+ }
84
+
85
+ /**
86
+ * Returns the CLI version that was used when this app was built
87
+ *
88
+ * @returns string
89
+ */
90
+ export function getCLIVersion(): string {
91
+ return process.env.AGENTUITY_CLI_VERSION ?? 'unknown';
92
+ }
93
+
94
+ /**
95
+ * Returns the environment setting for this app
96
+ *
97
+ * @returns string
98
+ */
99
+ export function getEnvironment(): string {
100
+ return process.env.AGENTUITY_ENVIRONMENT || process.env.NODE_ENV || 'development';
101
+ }