@clinebot/core 0.0.4 → 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 (79) hide show
  1. package/dist/agents/agent-config-parser.d.ts +1 -1
  2. package/dist/index.d.ts +5 -2
  3. package/dist/index.node.d.ts +1 -0
  4. package/dist/index.node.js +134 -107
  5. package/dist/runtime/session-runtime.d.ts +4 -2
  6. package/dist/session/default-session-manager.d.ts +5 -1
  7. package/dist/session/session-host.d.ts +3 -1
  8. package/dist/session/session-manager.d.ts +2 -1
  9. package/dist/session/unified-session-persistence-service.d.ts +4 -0
  10. package/dist/telemetry/ITelemetryAdapter.d.ts +54 -0
  11. package/dist/telemetry/LoggerTelemetryAdapter.d.ts +21 -0
  12. package/dist/telemetry/OpenTelemetryAdapter.d.ts +43 -0
  13. package/dist/telemetry/OpenTelemetryProvider.d.ts +41 -0
  14. package/dist/telemetry/TelemetryService.d.ts +34 -0
  15. package/dist/telemetry/opentelemetry.d.ts +3 -0
  16. package/dist/telemetry/opentelemetry.js +27 -0
  17. package/dist/{default-tools → tools}/schemas.d.ts +6 -0
  18. package/dist/types/config.d.ts +3 -2
  19. package/package.json +17 -3
  20. package/src/agents/agent-config-parser.ts +1 -1
  21. package/src/agents/hooks-config-loader.ts +19 -1
  22. package/src/index.node.ts +3 -0
  23. package/src/index.ts +35 -19
  24. package/src/providers/local-provider-service.ts +25 -7
  25. package/src/runtime/hook-file-hooks.test.ts +47 -0
  26. package/src/runtime/hook-file-hooks.ts +3 -0
  27. package/src/runtime/runtime-builder.test.ts +20 -0
  28. package/src/runtime/runtime-builder.ts +3 -2
  29. package/src/runtime/runtime-parity.test.ts +1 -1
  30. package/src/runtime/session-runtime.ts +4 -2
  31. package/src/session/default-session-manager.test.ts +72 -0
  32. package/src/session/default-session-manager.ts +63 -6
  33. package/src/session/session-host.ts +7 -2
  34. package/src/session/session-manager.ts +2 -1
  35. package/src/session/unified-session-persistence-service.ts +213 -23
  36. package/src/telemetry/ITelemetryAdapter.ts +94 -0
  37. package/src/telemetry/LoggerTelemetryAdapter.test.ts +42 -0
  38. package/src/telemetry/LoggerTelemetryAdapter.ts +114 -0
  39. package/src/telemetry/OpenTelemetryAdapter.test.ts +157 -0
  40. package/src/telemetry/OpenTelemetryAdapter.ts +348 -0
  41. package/src/telemetry/OpenTelemetryProvider.test.ts +113 -0
  42. package/src/telemetry/OpenTelemetryProvider.ts +322 -0
  43. package/src/telemetry/TelemetryService.test.ts +134 -0
  44. package/src/telemetry/TelemetryService.ts +141 -0
  45. package/src/telemetry/opentelemetry.ts +20 -0
  46. package/src/{default-tools → tools}/definitions.ts +35 -28
  47. package/src/{default-tools → tools}/schemas.ts +9 -0
  48. package/src/types/config.ts +3 -1
  49. /package/dist/{default-tools → tools}/constants.d.ts +0 -0
  50. /package/dist/{default-tools → tools}/definitions.d.ts +0 -0
  51. /package/dist/{default-tools → tools}/executors/apply-patch-parser.d.ts +0 -0
  52. /package/dist/{default-tools → tools}/executors/apply-patch.d.ts +0 -0
  53. /package/dist/{default-tools → tools}/executors/bash.d.ts +0 -0
  54. /package/dist/{default-tools → tools}/executors/editor.d.ts +0 -0
  55. /package/dist/{default-tools → tools}/executors/file-read.d.ts +0 -0
  56. /package/dist/{default-tools → tools}/executors/index.d.ts +0 -0
  57. /package/dist/{default-tools → tools}/executors/search.d.ts +0 -0
  58. /package/dist/{default-tools → tools}/executors/web-fetch.d.ts +0 -0
  59. /package/dist/{default-tools → tools}/index.d.ts +0 -0
  60. /package/dist/{default-tools → tools}/model-tool-routing.d.ts +0 -0
  61. /package/dist/{default-tools → tools}/presets.d.ts +0 -0
  62. /package/dist/{default-tools → tools}/types.d.ts +0 -0
  63. /package/src/{default-tools → tools}/constants.ts +0 -0
  64. /package/src/{default-tools → tools}/definitions.test.ts +0 -0
  65. /package/src/{default-tools → tools}/executors/apply-patch-parser.ts +0 -0
  66. /package/src/{default-tools → tools}/executors/apply-patch.ts +0 -0
  67. /package/src/{default-tools → tools}/executors/bash.ts +0 -0
  68. /package/src/{default-tools → tools}/executors/editor.ts +0 -0
  69. /package/src/{default-tools → tools}/executors/file-read.test.ts +0 -0
  70. /package/src/{default-tools → tools}/executors/file-read.ts +0 -0
  71. /package/src/{default-tools → tools}/executors/index.ts +0 -0
  72. /package/src/{default-tools → tools}/executors/search.ts +0 -0
  73. /package/src/{default-tools → tools}/executors/web-fetch.ts +0 -0
  74. /package/src/{default-tools → tools}/index.ts +0 -0
  75. /package/src/{default-tools → tools}/model-tool-routing.test.ts +0 -0
  76. /package/src/{default-tools → tools}/model-tool-routing.ts +0 -0
  77. /package/src/{default-tools → tools}/presets.test.ts +0 -0
  78. /package/src/{default-tools → tools}/presets.ts +0 -0
  79. /package/src/{default-tools → tools}/types.ts +0 -0
@@ -1,12 +1,13 @@
1
1
  import type { AgentConfig, AgentHooks, AgentResult, AgentTeamsRuntime, Tool } from "@clinebot/agents";
2
- import type { BasicLogger } from "@clinebot/shared";
2
+ import type { BasicLogger, ITelemetryService } from "@clinebot/shared";
3
3
  import type { UserInstructionConfigWatcher } from "../agents";
4
- import type { ToolExecutors } from "../default-tools";
4
+ import type { ToolExecutors } from "../tools";
5
5
  import type { CoreSessionConfig } from "../types/config";
6
6
  export interface BuiltRuntime {
7
7
  tools: Tool[];
8
8
  hooks?: AgentHooks;
9
9
  logger?: BasicLogger;
10
+ telemetry?: ITelemetryService;
10
11
  teamRuntime?: AgentTeamsRuntime;
11
12
  completionGuard?: () => string | undefined;
12
13
  shutdown: (reason: string) => Promise<void> | void;
@@ -21,6 +22,7 @@ export interface RuntimeBuilderInput {
21
22
  userInstructionWatcher?: UserInstructionConfigWatcher;
22
23
  defaultToolExecutors?: Partial<ToolExecutors>;
23
24
  logger?: BasicLogger;
25
+ telemetry?: ITelemetryService;
24
26
  }
25
27
  export interface RuntimeBuilder {
26
28
  build(input: RuntimeBuilderInput): BuiltRuntime;
@@ -1,8 +1,9 @@
1
1
  import { Agent, type AgentConfig, type AgentResult, type ToolApprovalRequest, type ToolApprovalResult } from "@clinebot/agents";
2
2
  import type { providers as LlmsProviders } from "@clinebot/llms";
3
- import { type ToolExecutors } from "../default-tools";
3
+ import { type ITelemetryService } from "@clinebot/shared";
4
4
  import type { RuntimeBuilder } from "../runtime/session-runtime";
5
5
  import { ProviderSettingsManager } from "../storage/provider-settings-manager";
6
+ import { type ToolExecutors } from "../tools";
6
7
  import type { CoreSessionEvent } from "../types/events";
7
8
  import type { SessionRecord } from "../types/sessions";
8
9
  import type { RpcCoreSessionService } from "./rpc-session-service";
@@ -19,6 +20,7 @@ export interface DefaultSessionManagerOptions {
19
20
  toolPolicies?: AgentConfig["toolPolicies"];
20
21
  providerSettingsManager?: ProviderSettingsManager;
21
22
  oauthTokenManager?: RuntimeOAuthTokenManager;
23
+ telemetry?: ITelemetryService;
22
24
  requestToolApproval?: (request: ToolApprovalRequest) => Promise<ToolApprovalResult>;
23
25
  }
24
26
  export declare class DefaultSessionManager implements SessionManager {
@@ -29,6 +31,7 @@ export declare class DefaultSessionManager implements SessionManager {
29
31
  private readonly defaultToolPolicies?;
30
32
  private readonly providerSettingsManager;
31
33
  private readonly oauthTokenManager;
34
+ private readonly defaultTelemetry?;
32
35
  private readonly defaultRequestToolApproval?;
33
36
  private readonly listeners;
34
37
  private readonly sessions;
@@ -75,5 +78,6 @@ export declare class DefaultSessionManager implements SessionManager {
75
78
  private runWithAuthRetry;
76
79
  private isLikelyAuthError;
77
80
  private syncOAuthCredentials;
81
+ updateSessionModel(sessionId: string, modelId: string): Promise<void>;
78
82
  }
79
83
  export {};
@@ -1,5 +1,6 @@
1
1
  import type { AgentConfig, ToolApprovalRequest, ToolApprovalResult } from "@clinebot/agents";
2
- import type { ToolExecutors } from "../default-tools";
2
+ import type { ITelemetryService } from "@clinebot/shared";
3
+ import type { ToolExecutors } from "../tools";
3
4
  import { RpcCoreSessionService } from "./rpc-session-service";
4
5
  import type { SessionManager } from "./session-manager";
5
6
  import { CoreSessionService } from "./session-service";
@@ -13,6 +14,7 @@ export interface CreateSessionHostOptions {
13
14
  rpcConnectAttempts?: number;
14
15
  rpcConnectDelayMs?: number;
15
16
  defaultToolExecutors?: Partial<ToolExecutors>;
17
+ telemetry?: ITelemetryService;
16
18
  toolPolicies?: AgentConfig["toolPolicies"];
17
19
  requestToolApproval?: (request: ToolApprovalRequest) => Promise<ToolApprovalResult>;
18
20
  }
@@ -15,7 +15,7 @@ export interface StartSessionInput {
15
15
  userFiles?: string[];
16
16
  userInstructionWatcher?: import("../agents").UserInstructionConfigWatcher;
17
17
  onTeamRestored?: () => void;
18
- defaultToolExecutors?: Partial<import("../default-tools").ToolExecutors>;
18
+ defaultToolExecutors?: Partial<import("../tools").ToolExecutors>;
19
19
  toolPolicies?: import("@clinebot/agents").AgentConfig["toolPolicies"];
20
20
  requestToolApproval?: (request: import("@clinebot/agents").ToolApprovalRequest) => Promise<import("@clinebot/agents").ToolApprovalResult>;
21
21
  }
@@ -55,4 +55,5 @@ export interface SessionManager {
55
55
  readTranscript(sessionId: string, maxChars?: number): Promise<string>;
56
56
  readHooks(sessionId: string, limit?: number): Promise<unknown[]>;
57
57
  subscribe(listener: (event: CoreSessionEvent) => void): () => void;
58
+ updateSessionModel?(sessionId: string, modelId: string): Promise<void>;
58
59
  }
@@ -12,6 +12,7 @@ export interface PersistedSessionUpdateInput {
12
12
  exitCode?: number | null;
13
13
  prompt?: string | null;
14
14
  metadataJson?: string | null;
15
+ title?: string | null;
15
16
  parentSessionId?: string | null;
16
17
  parentAgentId?: string | null;
17
18
  agentId?: string | null;
@@ -55,6 +56,8 @@ export declare class UnifiedSessionPersistenceService {
55
56
  private activeTeamTaskSessionId;
56
57
  private subagentArtifactPaths;
57
58
  private writeSessionManifestFile;
59
+ private readSessionManifestFile;
60
+ private applyResolvedTitleToRow;
58
61
  private createRootSessionId;
59
62
  createRootSessionWithArtifacts(input: CreateRootSessionWithArtifactsInput): Promise<RootSessionArtifacts>;
60
63
  writeSessionManifest(manifestPath: string, manifest: SessionManifest): void;
@@ -66,6 +69,7 @@ export declare class UnifiedSessionPersistenceService {
66
69
  sessionId: string;
67
70
  prompt?: string | null;
68
71
  metadata?: Record<string, unknown> | null;
72
+ title?: string | null;
69
73
  }): Promise<{
70
74
  updated: boolean;
71
75
  }>;
@@ -0,0 +1,54 @@
1
+ /**
2
+ * Telemetry adapter interface for the @clinebot/core SDK.
3
+ *
4
+ * This is the SDK-side counterpart to the extension's ITelemetryProvider.
5
+ * It is intentionally free of VS Code / host-provider dependencies so that
6
+ * any consumer (CLI, tests, third-party integrations) can plug in their own
7
+ * backend without pulling in the full extension runtime.
8
+ */
9
+ import type { TelemetryProperties } from "@clinebot/shared";
10
+ export type { TelemetryArray, TelemetryMetadata, TelemetryObject, TelemetryPrimitive, TelemetryProperties, TelemetryValue, } from "@clinebot/shared";
11
+ /**
12
+ * Telemetry adapter that an SDK consumer implements (or uses via the
13
+ * provided {@link OpenTelemetryAdapter}) to receive Cline telemetry events.
14
+ *
15
+ * The interface intentionally mirrors ITelemetryProvider from the extension
16
+ * so that shared logic can be re-used or compared easily.
17
+ */
18
+ export interface ITelemetryAdapter {
19
+ /** Human-readable adapter name used for logging / diagnostics. */
20
+ readonly name: string;
21
+ /**
22
+ * Emit a standard telemetry event.
23
+ * Implementations may silently drop events when telemetry is disabled.
24
+ */
25
+ emit(event: string, properties?: TelemetryProperties): void;
26
+ /**
27
+ * Emit a *required* telemetry event that must not be suppressed by
28
+ * user opt-out settings (e.g. final opt-out confirmation events).
29
+ */
30
+ emitRequired(event: string, properties?: TelemetryProperties): void;
31
+ /**
32
+ * Record a monotonically-increasing counter metric.
33
+ * Implementations that do not support metrics may treat this as a no-op.
34
+ */
35
+ recordCounter(name: string, value: number, attributes?: TelemetryProperties, description?: string, required?: boolean): void;
36
+ /**
37
+ * Record a histogram (distribution) metric.
38
+ * Implementations that do not support metrics may treat this as a no-op.
39
+ */
40
+ recordHistogram(name: string, value: number, attributes?: TelemetryProperties, description?: string, required?: boolean): void;
41
+ /**
42
+ * Record a gauge (point-in-time) metric.
43
+ * Pass `null` as `value` to retire the series identified by
44
+ * `name + attributes` and prevent stale gauge entries.
45
+ * Implementations that do not support metrics may treat this as a no-op.
46
+ */
47
+ recordGauge(name: string, value: number | null, attributes?: TelemetryProperties, description?: string, required?: boolean): void;
48
+ /** Returns whether the adapter is currently accepting events. */
49
+ isEnabled(): boolean;
50
+ /** Flush any buffered events/metrics to the backend. */
51
+ flush(): Promise<void>;
52
+ /** Release all resources held by the adapter. */
53
+ dispose(): Promise<void>;
54
+ }
@@ -0,0 +1,21 @@
1
+ import type { BasicLogger } from "@clinebot/shared";
2
+ import type { ITelemetryAdapter, TelemetryProperties } from "./ITelemetryAdapter";
3
+ export interface LoggerTelemetryAdapterOptions {
4
+ logger?: BasicLogger;
5
+ name?: string;
6
+ enabled?: boolean | (() => boolean);
7
+ }
8
+ export declare class LoggerTelemetryAdapter implements ITelemetryAdapter {
9
+ readonly name: string;
10
+ private readonly logger?;
11
+ private readonly enabled;
12
+ constructor(options?: LoggerTelemetryAdapterOptions);
13
+ emit(event: string, properties?: TelemetryProperties): void;
14
+ emitRequired(event: string, properties?: TelemetryProperties): void;
15
+ recordCounter(name: string, value: number, attributes?: TelemetryProperties, description?: string, required?: boolean): void;
16
+ recordHistogram(name: string, value: number, attributes?: TelemetryProperties, description?: string, required?: boolean): void;
17
+ recordGauge(name: string, value: number | null, attributes?: TelemetryProperties, description?: string, required?: boolean): void;
18
+ isEnabled(): boolean;
19
+ flush(): Promise<void>;
20
+ dispose(): Promise<void>;
21
+ }
@@ -0,0 +1,43 @@
1
+ import type { LoggerProvider } from "@opentelemetry/sdk-logs";
2
+ import type { MeterProvider } from "@opentelemetry/sdk-metrics";
3
+ import type { ITelemetryAdapter, TelemetryMetadata, TelemetryProperties } from "./ITelemetryAdapter";
4
+ export interface OpenTelemetryAdapterOptions {
5
+ readonly metadata: TelemetryMetadata;
6
+ readonly meterProvider?: MeterProvider | null;
7
+ readonly loggerProvider?: LoggerProvider | null;
8
+ readonly name?: string;
9
+ readonly enabled?: boolean | (() => boolean);
10
+ readonly distinctId?: string;
11
+ readonly commonProperties?: TelemetryProperties;
12
+ }
13
+ export declare class OpenTelemetryAdapter implements ITelemetryAdapter {
14
+ readonly name: string;
15
+ private readonly metadata;
16
+ private readonly meter;
17
+ private readonly logger;
18
+ private readonly enabled;
19
+ private distinctId?;
20
+ private commonProperties;
21
+ private counters;
22
+ private histograms;
23
+ private gauges;
24
+ private gaugeValues;
25
+ private readonly meterProvider?;
26
+ private readonly loggerProvider?;
27
+ constructor(options: OpenTelemetryAdapterOptions);
28
+ emit(event: string, properties?: TelemetryProperties): void;
29
+ emitRequired(event: string, properties?: TelemetryProperties): void;
30
+ recordCounter(name: string, value: number, attributes?: TelemetryProperties, description?: string, required?: boolean): void;
31
+ recordHistogram(name: string, value: number, attributes?: TelemetryProperties, description?: string, required?: boolean): void;
32
+ recordGauge(name: string, value: number | null, attributes?: TelemetryProperties, description?: string, required?: boolean): void;
33
+ isEnabled(): boolean;
34
+ setDistinctId(distinctId?: string): void;
35
+ setCommonProperties(properties: TelemetryProperties): void;
36
+ updateCommonProperties(properties: TelemetryProperties): void;
37
+ flush(): Promise<void>;
38
+ dispose(): Promise<void>;
39
+ private emitLog;
40
+ private buildAttributes;
41
+ private snapshotGaugeSeries;
42
+ private flattenProperties;
43
+ }
@@ -0,0 +1,41 @@
1
+ import type { BasicLogger, ITelemetryService, OpenTelemetryClientConfig, TelemetryMetadata } from "@clinebot/shared";
2
+ import { LoggerProvider } from "@opentelemetry/sdk-logs";
3
+ import { MeterProvider } from "@opentelemetry/sdk-metrics";
4
+ import { OpenTelemetryAdapter, type OpenTelemetryAdapterOptions } from "./OpenTelemetryAdapter";
5
+ type OpenTelemetryExporterKind = "console" | "otlp";
6
+ export interface OpenTelemetryProviderOptions extends Omit<OpenTelemetryClientConfig, "enabled" | "logsExporter" | "metricsExporter"> {
7
+ serviceName?: string;
8
+ serviceVersion?: string;
9
+ enabled?: boolean;
10
+ logsExporter?: string | OpenTelemetryExporterKind[];
11
+ metricsExporter?: string | OpenTelemetryExporterKind[];
12
+ metricExportIntervalMs?: number;
13
+ logMaxQueueSize?: number;
14
+ logBatchSize?: number;
15
+ logBatchTimeoutMs?: number;
16
+ }
17
+ export interface CreateOpenTelemetryTelemetryServiceOptions extends OpenTelemetryProviderOptions, Pick<OpenTelemetryAdapterOptions, "name" | "distinctId" | "commonProperties"> {
18
+ metadata: TelemetryMetadata;
19
+ logger?: BasicLogger;
20
+ }
21
+ export declare class OpenTelemetryProvider {
22
+ readonly meterProvider: MeterProvider | null;
23
+ readonly loggerProvider: LoggerProvider | null;
24
+ private readonly options;
25
+ constructor(options?: OpenTelemetryProviderOptions);
26
+ createAdapter(options: Omit<OpenTelemetryAdapterOptions, "meterProvider" | "loggerProvider">): OpenTelemetryAdapter;
27
+ createTelemetryService(options: Omit<CreateOpenTelemetryTelemetryServiceOptions, keyof OpenTelemetryProviderOptions>): ITelemetryService;
28
+ forceFlush(): Promise<void>;
29
+ dispose(): Promise<void>;
30
+ private createMeterProvider;
31
+ private createLoggerProvider;
32
+ }
33
+ export declare function createOpenTelemetryTelemetryService(options: CreateOpenTelemetryTelemetryServiceOptions): {
34
+ provider: OpenTelemetryProvider;
35
+ telemetry: ITelemetryService;
36
+ };
37
+ export declare function createConfiguredTelemetryService(options: CreateOpenTelemetryTelemetryServiceOptions): {
38
+ provider?: OpenTelemetryProvider;
39
+ telemetry: ITelemetryService;
40
+ };
41
+ export {};
@@ -0,0 +1,34 @@
1
+ import type { BasicLogger, ITelemetryService, TelemetryMetadata, TelemetryProperties } from "@clinebot/shared";
2
+ import type { ITelemetryAdapter } from "./ITelemetryAdapter";
3
+ export interface TelemetryServiceOptions {
4
+ adapters?: ITelemetryAdapter[];
5
+ metadata?: Partial<TelemetryMetadata>;
6
+ distinctId?: string;
7
+ commonProperties?: TelemetryProperties;
8
+ logger?: BasicLogger;
9
+ }
10
+ export declare class TelemetryService implements ITelemetryService {
11
+ private adapters;
12
+ private metadata;
13
+ private distinctId?;
14
+ private commonProperties;
15
+ constructor(options?: TelemetryServiceOptions);
16
+ addAdapter(adapter: ITelemetryAdapter): void;
17
+ setDistinctId(distinctId?: string): void;
18
+ setMetadata(metadata: Partial<TelemetryMetadata>): void;
19
+ updateMetadata(metadata: Partial<TelemetryMetadata>): void;
20
+ setCommonProperties(properties: TelemetryProperties): void;
21
+ updateCommonProperties(properties: TelemetryProperties): void;
22
+ isEnabled(): boolean;
23
+ capture(input: {
24
+ event: string;
25
+ properties?: TelemetryProperties;
26
+ }): void;
27
+ captureRequired(event: string, properties?: TelemetryProperties): void;
28
+ recordCounter(name: string, value: number, attributes?: TelemetryProperties, description?: string, required?: boolean): void;
29
+ recordHistogram(name: string, value: number, attributes?: TelemetryProperties, description?: string, required?: boolean): void;
30
+ recordGauge(name: string, value: number | null, attributes?: TelemetryProperties, description?: string, required?: boolean): void;
31
+ flush(): Promise<void>;
32
+ dispose(): Promise<void>;
33
+ private buildAttributes;
34
+ }
@@ -0,0 +1,3 @@
1
+ export type { ITelemetryAdapter, TelemetryArray, TelemetryMetadata, TelemetryObject, TelemetryPrimitive, TelemetryProperties, TelemetryValue, } from "./ITelemetryAdapter";
2
+ export { OpenTelemetryAdapter, type OpenTelemetryAdapterOptions, } from "./OpenTelemetryAdapter";
3
+ export { type CreateOpenTelemetryTelemetryServiceOptions, createConfiguredTelemetryService, createOpenTelemetryTelemetryService, OpenTelemetryProvider, type OpenTelemetryProviderOptions, } from "./OpenTelemetryProvider";