@privateconnect/sdk 0.7.3 → 0.7.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/dist/index.d.ts +7 -5
- package/dist/index.js +1 -1
- package/package.json +33 -33
package/dist/index.d.ts
CHANGED
|
@@ -85,8 +85,10 @@ export interface Grant {
|
|
|
85
85
|
resourceType: string;
|
|
86
86
|
resourceName: string;
|
|
87
87
|
scope: string;
|
|
88
|
-
|
|
89
|
-
|
|
88
|
+
tokenPrefix?: string;
|
|
89
|
+
persistent: boolean;
|
|
90
|
+
expiresAt: string | null;
|
|
91
|
+
expiresInMinutes?: number | null;
|
|
90
92
|
token?: string;
|
|
91
93
|
endpoint?: string;
|
|
92
94
|
}
|
|
@@ -95,8 +97,8 @@ export interface GrantCreateOptions {
|
|
|
95
97
|
resourceType: 'db' | 'api' | 'path';
|
|
96
98
|
resourceName: string;
|
|
97
99
|
scope?: 'read-only' | 'full';
|
|
98
|
-
/** Duration string: 60s, 5m, 1h, 1d */
|
|
99
|
-
ttl
|
|
100
|
+
/** Duration string: 60s, 5m, 1h, 1d. Omit for persistent grant. */
|
|
101
|
+
ttl?: string;
|
|
100
102
|
}
|
|
101
103
|
export declare class AgentsAPI {
|
|
102
104
|
private client;
|
|
@@ -172,7 +174,7 @@ export declare class PrivateConnect {
|
|
|
172
174
|
agents: AgentsAPI;
|
|
173
175
|
/** Services API for connecting to services */
|
|
174
176
|
services: ServicesAPI;
|
|
175
|
-
/** Grants API for managing time-limited
|
|
177
|
+
/** Grants API for managing scoped access tokens (time-limited or persistent) */
|
|
176
178
|
grants: GrantsAPI;
|
|
177
179
|
constructor(config: PrivateConnectConfig);
|
|
178
180
|
/** The resolved agent ID, or undefined if not configured. */
|
package/dist/index.js
CHANGED
|
@@ -358,4 +358,4 @@ async function connect(serviceName, config) {
|
|
|
358
358
|
const client = new PrivateConnect({ ...config, apiKey });
|
|
359
359
|
return client.connect(serviceName, { grantToken: config?.grantToken });
|
|
360
360
|
}
|
|
361
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Private Connect SDK\n *\n * Programmatic access to Private Connect services, grants, and agent orchestration.\n *\n * @example\n * ```typescript\n * import { PrivateConnect } from '@privateconnect/sdk';\n *\n * const pc = new PrivateConnect({ apiKey: 'your-api-key' });\n *\n * // Connect to a service (assumes tunnel is already open)\n * const db = await pc.connect('postgres-prod');\n * console.log(db.connectionString); // postgres://localhost:5432/...\n *\n * // Grant an AI agent temporary access\n * const grant = await pc.grants.create({\n *   agentLabel: 'claude',\n *   resourceType: 'db',\n *   resourceName: 'postgres',\n *   ttl: '5m',\n * });\n * console.log(grant.token); // gnt_...\n *\n * // List all agents\n * const agents = await pc.agents.list();\n * ```\n */\n\nimport * as fs from 'fs';\nimport * as path from 'path';\nimport * as os from 'os';\n\n// ─────────────────────────────────────────────────────────────────────────────\n// Types\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport interface PrivateConnectConfig {\n  /** API key for authentication */\n  apiKey: string;\n  /** Hub URL (default: https://api.privateconnect.co) */\n  hubUrl?: string;\n  /** Agent ID (auto-detected from local config if not provided) */\n  agentId?: string;\n  /** Disable usage tracking (default: false) */\n  disableTracking?: boolean;\n}\n\nexport interface Service {\n  id: string;\n  name: string;\n  targetHost: string;\n  targetPort: number;\n  tunnelPort?: number;\n  protocol: string;\n  status: string;\n  agentLabel?: string;\n}\n\nexport interface Agent {\n  id: string;\n  name?: string;\n  label: string;\n  isOnline: boolean;\n  lastSeenAt: string;\n  capabilities: string[];\n  services: string[];\n}\n\nexport interface Connection {\n  service: string;\n  host: string;\n  port: number;\n  connectionString: string;\n  envVar: string;\n  /** Present when using a grant-based connection */\n  grantToken?: string;\n  /** Present when using a grant-based connection */\n  grantEndpoint?: string;\n}\n\nexport interface Message {\n  id: string;\n  from: { id: string; name?: string; label?: string };\n  channel: string;\n  type: string;\n  payload: Record<string, unknown>;\n  createdAt: string;\n  isRead: boolean;\n}\n\nexport interface Grant {\n  id: string;\n  agentLabel: string;\n  resourceType: string;\n  resourceName: string;\n  scope: string;\n  expiresAt: string;\n  expiresInMinutes?: number;\n  token?: string;\n  endpoint?: string;\n}\n\nexport interface GrantCreateOptions {\n  agentLabel: string;\n  resourceType: 'db' | 'api' | 'path';\n  resourceName: string;\n  scope?: 'read-only' | 'full';\n  /** Duration string: 60s, 5m, 1h, 1d */\n  ttl: string;\n}\n\n// ─────────────────────────────────────────────────────────────────────────────\n// Tracking\n// ─────────────────────────────────────────────────────────────────────────────\n\nfunction trackSdkUsage(hubUrl: string): void {\n  const data = JSON.stringify({\n    os: typeof process !== 'undefined' ? process.platform : 'browser',\n    arch: typeof process !== 'undefined' ? (process.arch === 'arm64' ? 'arm64' : 'x64') : 'unknown',\n    version: 'sdk',\n    source: 'sdk',\n  });\n\n  fetch(`${hubUrl}/v1/events/install`, {\n    method: 'POST',\n    headers: { 'Content-Type': 'application/json' },\n    body: data,\n  }).catch(() => {});\n}\n\n// ─────────────────────────────────────────────────────────────────────────────\n// Agent ID Detection\n// ─────────────────────────────────────────────────────────────────────────────\n\nconst CONFIG_PATH = path.join(os.homedir(), '.private-connect', 'config.json');\n\n/**\n * Detect the agent ID from local config or environment.\n * Returns undefined if no agent is configured — callers that need an agent ID\n * should surface a clear error rather than using a fake one.\n */\nfunction detectAgentId(): string | undefined {\n  // 1. Environment variables (highest priority — useful in CI)\n  const envId = process.env.PRIVATECONNECT_AGENT_ID || process.env.CONNECT_AGENT_ID;\n  if (envId) return envId;\n\n  // 2. Local config file (~/.private-connect/config.json)\n  try {\n    if (fs.existsSync(CONFIG_PATH)) {\n      const raw = fs.readFileSync(CONFIG_PATH, 'utf-8');\n      const config = JSON.parse(raw);\n      if (config.agentId && typeof config.agentId === 'string') {\n        return config.agentId;\n      }\n    }\n  } catch {\n    // Config unreadable or malformed — fall through\n  }\n\n  return undefined;\n}\n\n// ─────────────────────────────────────────────────────────────────────────────\n// Agents API\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport class AgentsAPI {\n  constructor(private client: PrivateConnect) {}\n\n  async list(options?: { onlineOnly?: boolean }): Promise<Agent[]> {\n    const response = await this.client.fetch('/v1/agents/orchestration');\n    const data = await response.json();\n    let agents = data.agents || [];\n\n    if (options?.onlineOnly) {\n      agents = agents.filter((a: any) => a.isOnline);\n    }\n\n    return agents.map((a: any) => ({\n      id: a.id,\n      name: a.name,\n      label: a.label,\n      isOnline: a.isOnline,\n      lastSeenAt: a.lastSeenAt,\n      capabilities: a.capabilities?.map((c: any) => c.name) || [],\n      services: a.services?.map((s: any) => s.name) || [],\n    }));\n  }\n\n  async findByCapability(capability: string): Promise<Agent[]> {\n    const response = await this.client.fetch(`/v1/agents/by-capability/${encodeURIComponent(capability)}`);\n    const data = await response.json();\n    return data.agents || [];\n  }\n\n  async registerCapabilities(capabilities: Array<{ name: string; metadata?: Record<string, unknown> }>): Promise<void> {\n    const agentId = this.client.requireAgentId();\n    await this.client.fetch(`/v1/agents/${agentId}/capabilities`, {\n      method: 'POST',\n      body: JSON.stringify({ capabilities }),\n    });\n  }\n\n  async sendMessage(\n    toAgentId: string,\n    payload: Record<string, unknown>,\n    options?: { channel?: string; type?: 'request' | 'response' | 'event' }\n  ): Promise<{ messageId: string }> {\n    const agentId = this.client.requireAgentId();\n    const response = await this.client.fetch(`/v1/agents/${agentId}/messages/send`, {\n      method: 'POST',\n      body: JSON.stringify({ toAgentId, payload, ...options }),\n    });\n    return response.json();\n  }\n\n  async broadcast(\n    payload: Record<string, unknown>,\n    options?: { channel?: string }\n  ): Promise<{ sent: number }> {\n    const agentId = this.client.requireAgentId();\n    const response = await this.client.fetch(`/v1/agents/${agentId}/messages/broadcast`, {\n      method: 'POST',\n      body: JSON.stringify({ payload, ...options }),\n    });\n    return response.json();\n  }\n\n  async getMessages(options?: { channel?: string; unreadOnly?: boolean; limit?: number }): Promise<Message[]> {\n    const agentId = this.client.requireAgentId();\n    const params = new URLSearchParams();\n    if (options?.channel) params.set('channel', options.channel);\n    if (options?.unreadOnly !== undefined) params.set('unreadOnly', String(options.unreadOnly));\n    if (options?.limit) params.set('limit', String(options.limit));\n\n    const response = await this.client.fetch(`/v1/agents/${agentId}/messages?${params}`);\n    const data = await response.json();\n    return data.messages || [];\n  }\n\n  async markRead(messageIds: string[]): Promise<void> {\n    const agentId = this.client.requireAgentId();\n    await this.client.fetch(`/v1/agents/${agentId}/messages/read`, {\n      method: 'POST',\n      body: JSON.stringify({ messageIds }),\n    });\n  }\n}\n\n// ─────────────────────────────────────────────────────────────────────────────\n// Services API\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport class ServicesAPI {\n  constructor(private client: PrivateConnect) {}\n\n  async list(): Promise<Service[]> {\n    const response = await this.client.fetch('/v1/services');\n    return response.json();\n  }\n\n  async get(name: string): Promise<Service | null> {\n    const services = await this.list();\n    return services.find(s => s.name.toLowerCase() === name.toLowerCase()) || null;\n  }\n\n  /**\n   * Get connection details for a service.\n   *\n   * If `grantToken` is provided, returns a proxied connection via the hub's\n   * grant endpoint instead of assuming a local tunnel.\n   */\n  async getConnection(serviceName: string, options?: { grantToken?: string }): Promise<Connection> {\n    if (options?.grantToken) {\n      return this.getGrantConnection(serviceName, options.grantToken);\n    }\n\n    const service = await this.get(serviceName);\n    if (!service) {\n      throw new Error(`Service \"${serviceName}\" not found`);\n    }\n\n    const port = service.tunnelPort || service.targetPort;\n    const host = 'localhost';\n\n    let connectionString = '';\n    let envVar = 'SERVICE_URL';\n\n    if (service.targetPort === 5432 || service.protocol === 'postgres') {\n      connectionString = `postgres://${host}:${port}/postgres`;\n      envVar = 'DATABASE_URL';\n    } else if (service.targetPort === 3306 || service.protocol === 'mysql') {\n      connectionString = `mysql://${host}:${port}`;\n      envVar = 'DATABASE_URL';\n    } else if (service.targetPort === 6379 || service.protocol === 'redis') {\n      connectionString = `redis://${host}:${port}`;\n      envVar = 'REDIS_URL';\n    } else if (service.targetPort === 27017 || service.protocol === 'mongodb') {\n      connectionString = `mongodb://${host}:${port}`;\n      envVar = 'MONGODB_URI';\n    } else if (service.protocol === 'http' || service.protocol === 'https') {\n      connectionString = `http://${host}:${port}`;\n      envVar = 'API_URL';\n    } else {\n      connectionString = `tcp://${host}:${port}`;\n      envVar = `${serviceName.toUpperCase().replace(/-/g, '_')}_URL`;\n    }\n\n    return { service: serviceName, host, port, connectionString, envVar };\n  }\n\n  private getGrantConnection(serviceName: string, grantToken: string): Connection {\n    const hubUrl = this.client.hubUrl;\n    const grantEndpoint = `${hubUrl}/grant/${encodeURIComponent(serviceName)}`;\n\n    return {\n      service: serviceName,\n      host: new URL(hubUrl).hostname,\n      port: new URL(hubUrl).port ? parseInt(new URL(hubUrl).port, 10) : 443,\n      connectionString: grantEndpoint,\n      envVar: 'GRANT_URL',\n      grantToken,\n      grantEndpoint,\n    };\n  }\n}\n\n// ─────────────────────────────────────────────────────────────────────────────\n// Grants API\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport class GrantsAPI {\n  constructor(private client: PrivateConnect) {}\n\n  /**\n   * Create a time-limited access grant for an AI agent or external consumer.\n   */\n  async create(options: GrantCreateOptions): Promise<Grant> {\n    const response = await this.client.fetch('/v1/grants', {\n      method: 'POST',\n      body: JSON.stringify(options),\n    });\n    const data = await response.json();\n    return data.grant;\n  }\n\n  /**\n   * List active grants in the workspace.\n   */\n  async list(options?: { includeExpired?: boolean }): Promise<Grant[]> {\n    const params = new URLSearchParams();\n    if (options?.includeExpired) params.set('includeExpired', 'true');\n    const response = await this.client.fetch(`/v1/grants?${params}`);\n    const data = await response.json();\n    return data.grants || [];\n  }\n\n  /**\n   * Revoke an active grant immediately.\n   */\n  async revoke(grantId: string): Promise<void> {\n    await this.client.fetch(`/v1/grants/${grantId}`, { method: 'DELETE' });\n  }\n\n  /**\n   * Validate a grant token (public endpoint — no API key required).\n   * Returns the grant if valid, null otherwise.\n   */\n  async validate(token: string): Promise<Grant | null> {\n    try {\n      const url = `${this.client.hubUrl}/v1/grants/validate`;\n      const response = await fetch(url, {\n        method: 'POST',\n        headers: { 'Content-Type': 'application/json' },\n        body: JSON.stringify({ token }),\n      });\n      if (!response.ok) return null;\n      const data = await response.json();\n      return data.valid ? data.grant : null;\n    } catch {\n      return null;\n    }\n  }\n}\n\n// ─────────────────────────────────────────────────────────────────────────────\n// Main Client\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport class PrivateConnect {\n  private config: { apiKey: string; hubUrl: string; agentId?: string };\n\n  /** Agents API for discovery and orchestration */\n  public agents: AgentsAPI;\n\n  /** Services API for connecting to services */\n  public services: ServicesAPI;\n\n  /** Grants API for managing time-limited access tokens */\n  public grants: GrantsAPI;\n\n  constructor(config: PrivateConnectConfig) {\n    this.config = {\n      apiKey: config.apiKey,\n      hubUrl: config.hubUrl || 'https://api.privateconnect.co',\n      agentId: config.agentId || detectAgentId(),\n    };\n\n    this.agents = new AgentsAPI(this);\n    this.services = new ServicesAPI(this);\n    this.grants = new GrantsAPI(this);\n\n    if (!config.disableTracking) {\n      trackSdkUsage(this.config.hubUrl);\n    }\n  }\n\n  /** The resolved agent ID, or undefined if not configured. */\n  get agentId(): string | undefined {\n    return this.config.agentId;\n  }\n\n  /** The hub URL this client is connected to. */\n  get hubUrl(): string {\n    return this.config.hubUrl;\n  }\n\n  /**\n   * Shorthand: get connection details for a service.\n   * Pass `grantToken` to connect via the grant proxy instead of a local tunnel.\n   */\n  async connect(serviceName: string, options?: { grantToken?: string }): Promise<Connection> {\n    return this.services.getConnection(serviceName, options);\n  }\n\n  /**\n   * Returns the agent ID or throws if not configured.\n   * Used by APIs that require an authenticated agent identity.\n   */\n  requireAgentId(): string {\n    if (!this.config.agentId) {\n      throw new Error(\n        'Agent ID not found. Either:\\n' +\n        '  1. Run \"connect up\" to register this machine, or\\n' +\n        '  2. Set PRIVATECONNECT_AGENT_ID environment variable, or\\n' +\n        '  3. Pass agentId in the PrivateConnect constructor.'\n      );\n    }\n    return this.config.agentId;\n  }\n\n  /** Internal fetch with API key auth. */\n  async fetch(path: string, options?: RequestInit): Promise<Response> {\n    const url = `${this.config.hubUrl}${path}`;\n    const response = await fetch(url, {\n      ...options,\n      headers: {\n        'x-api-key': this.config.apiKey,\n        'Content-Type': 'application/json',\n        ...options?.headers,\n      },\n    });\n\n    if (!response.ok) {\n      const error = await response.json().catch(() => ({ message: 'Unknown error' }));\n      throw new Error(error.message || `Request failed: ${response.status}`);\n    }\n\n    return response;\n  }\n}\n\nexport default PrivateConnect;\n\n/** Convenience function for quick one-off connections. */\nexport async function connect(\n  serviceName: string,\n  config?: PrivateConnectConfig & { grantToken?: string },\n): Promise<Connection> {\n  const apiKey = config?.apiKey || process.env.PRIVATECONNECT_API_KEY;\n  if (!apiKey) {\n    throw new Error('API key required. Set PRIVATECONNECT_API_KEY or pass config.apiKey');\n  }\n\n  const client = new PrivateConnect({ ...config, apiKey });\n  return client.connect(serviceName, { grantToken: config?.grantToken });\n}\n"]}
|
|
361
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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","sourcesContent":["/**\r\n * Private Connect SDK\r\n *\r\n * Programmatic access to Private Connect services, grants, and agent orchestration.\r\n *\r\n * @example\r\n * ```typescript\r\n * import { PrivateConnect } from '@privateconnect/sdk';\r\n *\r\n * const pc = new PrivateConnect({ apiKey: 'your-api-key' });\r\n *\r\n * // Connect to a service (assumes tunnel is already open)\r\n * const db = await pc.connect('postgres-prod');\r\n * console.log(db.connectionString); // postgres://localhost:5432/...\r\n *\r\n * // Grant an AI agent temporary access\r\n * const grant = await pc.grants.create({\r\n *   agentLabel: 'claude',\r\n *   resourceType: 'db',\r\n *   resourceName: 'postgres',\r\n *   ttl: '5m',\r\n * });\r\n * console.log(grant.token); // gnt_...\r\n *\r\n * // List all agents\r\n * const agents = await pc.agents.list();\r\n * ```\r\n */\r\n\r\nimport * as fs from 'fs';\r\nimport * as path from 'path';\r\nimport * as os from 'os';\r\n\r\n// ─────────────────────────────────────────────────────────────────────────────\r\n// Types\r\n// ─────────────────────────────────────────────────────────────────────────────\r\n\r\nexport interface PrivateConnectConfig {\r\n  /** API key for authentication */\r\n  apiKey: string;\r\n  /** Hub URL (default: https://api.privateconnect.co) */\r\n  hubUrl?: string;\r\n  /** Agent ID (auto-detected from local config if not provided) */\r\n  agentId?: string;\r\n  /** Disable usage tracking (default: false) */\r\n  disableTracking?: boolean;\r\n}\r\n\r\nexport interface Service {\r\n  id: string;\r\n  name: string;\r\n  targetHost: string;\r\n  targetPort: number;\r\n  tunnelPort?: number;\r\n  protocol: string;\r\n  status: string;\r\n  agentLabel?: string;\r\n}\r\n\r\nexport interface Agent {\r\n  id: string;\r\n  name?: string;\r\n  label: string;\r\n  isOnline: boolean;\r\n  lastSeenAt: string;\r\n  capabilities: string[];\r\n  services: string[];\r\n}\r\n\r\nexport interface Connection {\r\n  service: string;\r\n  host: string;\r\n  port: number;\r\n  connectionString: string;\r\n  envVar: string;\r\n  /** Present when using a grant-based connection */\r\n  grantToken?: string;\r\n  /** Present when using a grant-based connection */\r\n  grantEndpoint?: string;\r\n}\r\n\r\nexport interface Message {\r\n  id: string;\r\n  from: { id: string; name?: string; label?: string };\r\n  channel: string;\r\n  type: string;\r\n  payload: Record<string, unknown>;\r\n  createdAt: string;\r\n  isRead: boolean;\r\n}\r\n\r\nexport interface Grant {\r\n  id: string;\r\n  agentLabel: string;\r\n  resourceType: string;\r\n  resourceName: string;\r\n  scope: string;\r\n  tokenPrefix?: string;\r\n  persistent: boolean;\r\n  expiresAt: string | null;\r\n  expiresInMinutes?: number | null;\r\n  token?: string;\r\n  endpoint?: string;\r\n}\r\n\r\nexport interface GrantCreateOptions {\r\n  agentLabel: string;\r\n  resourceType: 'db' | 'api' | 'path';\r\n  resourceName: string;\r\n  scope?: 'read-only' | 'full';\r\n  /** Duration string: 60s, 5m, 1h, 1d. Omit for persistent grant. */\r\n  ttl?: string;\r\n}\r\n\r\n// ─────────────────────────────────────────────────────────────────────────────\r\n// Tracking\r\n// ─────────────────────────────────────────────────────────────────────────────\r\n\r\nfunction trackSdkUsage(hubUrl: string): void {\r\n  const data = JSON.stringify({\r\n    os: typeof process !== 'undefined' ? process.platform : 'browser',\r\n    arch: typeof process !== 'undefined' ? (process.arch === 'arm64' ? 'arm64' : 'x64') : 'unknown',\r\n    version: 'sdk',\r\n    source: 'sdk',\r\n  });\r\n\r\n  fetch(`${hubUrl}/v1/events/install`, {\r\n    method: 'POST',\r\n    headers: { 'Content-Type': 'application/json' },\r\n    body: data,\r\n  }).catch(() => {});\r\n}\r\n\r\n// ─────────────────────────────────────────────────────────────────────────────\r\n// Agent ID Detection\r\n// ─────────────────────────────────────────────────────────────────────────────\r\n\r\nconst CONFIG_PATH = path.join(os.homedir(), '.private-connect', 'config.json');\r\n\r\n/**\r\n * Detect the agent ID from local config or environment.\r\n * Returns undefined if no agent is configured — callers that need an agent ID\r\n * should surface a clear error rather than using a fake one.\r\n */\r\nfunction detectAgentId(): string | undefined {\r\n  // 1. Environment variables (highest priority — useful in CI)\r\n  const envId = process.env.PRIVATECONNECT_AGENT_ID || process.env.CONNECT_AGENT_ID;\r\n  if (envId) return envId;\r\n\r\n  // 2. Local config file (~/.private-connect/config.json)\r\n  try {\r\n    if (fs.existsSync(CONFIG_PATH)) {\r\n      const raw = fs.readFileSync(CONFIG_PATH, 'utf-8');\r\n      const config = JSON.parse(raw);\r\n      if (config.agentId && typeof config.agentId === 'string') {\r\n        return config.agentId;\r\n      }\r\n    }\r\n  } catch {\r\n    // Config unreadable or malformed — fall through\r\n  }\r\n\r\n  return undefined;\r\n}\r\n\r\n// ─────────────────────────────────────────────────────────────────────────────\r\n// Agents API\r\n// ─────────────────────────────────────────────────────────────────────────────\r\n\r\nexport class AgentsAPI {\r\n  constructor(private client: PrivateConnect) {}\r\n\r\n  async list(options?: { onlineOnly?: boolean }): Promise<Agent[]> {\r\n    const response = await this.client.fetch('/v1/agents/orchestration');\r\n    const data = await response.json();\r\n    let agents = data.agents || [];\r\n\r\n    if (options?.onlineOnly) {\r\n      agents = agents.filter((a: any) => a.isOnline);\r\n    }\r\n\r\n    return agents.map((a: any) => ({\r\n      id: a.id,\r\n      name: a.name,\r\n      label: a.label,\r\n      isOnline: a.isOnline,\r\n      lastSeenAt: a.lastSeenAt,\r\n      capabilities: a.capabilities?.map((c: any) => c.name) || [],\r\n      services: a.services?.map((s: any) => s.name) || [],\r\n    }));\r\n  }\r\n\r\n  async findByCapability(capability: string): Promise<Agent[]> {\r\n    const response = await this.client.fetch(`/v1/agents/by-capability/${encodeURIComponent(capability)}`);\r\n    const data = await response.json();\r\n    return data.agents || [];\r\n  }\r\n\r\n  async registerCapabilities(capabilities: Array<{ name: string; metadata?: Record<string, unknown> }>): Promise<void> {\r\n    const agentId = this.client.requireAgentId();\r\n    await this.client.fetch(`/v1/agents/${agentId}/capabilities`, {\r\n      method: 'POST',\r\n      body: JSON.stringify({ capabilities }),\r\n    });\r\n  }\r\n\r\n  async sendMessage(\r\n    toAgentId: string,\r\n    payload: Record<string, unknown>,\r\n    options?: { channel?: string; type?: 'request' | 'response' | 'event' }\r\n  ): Promise<{ messageId: string }> {\r\n    const agentId = this.client.requireAgentId();\r\n    const response = await this.client.fetch(`/v1/agents/${agentId}/messages/send`, {\r\n      method: 'POST',\r\n      body: JSON.stringify({ toAgentId, payload, ...options }),\r\n    });\r\n    return response.json();\r\n  }\r\n\r\n  async broadcast(\r\n    payload: Record<string, unknown>,\r\n    options?: { channel?: string }\r\n  ): Promise<{ sent: number }> {\r\n    const agentId = this.client.requireAgentId();\r\n    const response = await this.client.fetch(`/v1/agents/${agentId}/messages/broadcast`, {\r\n      method: 'POST',\r\n      body: JSON.stringify({ payload, ...options }),\r\n    });\r\n    return response.json();\r\n  }\r\n\r\n  async getMessages(options?: { channel?: string; unreadOnly?: boolean; limit?: number }): Promise<Message[]> {\r\n    const agentId = this.client.requireAgentId();\r\n    const params = new URLSearchParams();\r\n    if (options?.channel) params.set('channel', options.channel);\r\n    if (options?.unreadOnly !== undefined) params.set('unreadOnly', String(options.unreadOnly));\r\n    if (options?.limit) params.set('limit', String(options.limit));\r\n\r\n    const response = await this.client.fetch(`/v1/agents/${agentId}/messages?${params}`);\r\n    const data = await response.json();\r\n    return data.messages || [];\r\n  }\r\n\r\n  async markRead(messageIds: string[]): Promise<void> {\r\n    const agentId = this.client.requireAgentId();\r\n    await this.client.fetch(`/v1/agents/${agentId}/messages/read`, {\r\n      method: 'POST',\r\n      body: JSON.stringify({ messageIds }),\r\n    });\r\n  }\r\n}\r\n\r\n// ─────────────────────────────────────────────────────────────────────────────\r\n// Services API\r\n// ─────────────────────────────────────────────────────────────────────────────\r\n\r\nexport class ServicesAPI {\r\n  constructor(private client: PrivateConnect) {}\r\n\r\n  async list(): Promise<Service[]> {\r\n    const response = await this.client.fetch('/v1/services');\r\n    return response.json();\r\n  }\r\n\r\n  async get(name: string): Promise<Service | null> {\r\n    const services = await this.list();\r\n    return services.find(s => s.name.toLowerCase() === name.toLowerCase()) || null;\r\n  }\r\n\r\n  /**\r\n   * Get connection details for a service.\r\n   *\r\n   * If `grantToken` is provided, returns a proxied connection via the hub's\r\n   * grant endpoint instead of assuming a local tunnel.\r\n   */\r\n  async getConnection(serviceName: string, options?: { grantToken?: string }): Promise<Connection> {\r\n    if (options?.grantToken) {\r\n      return this.getGrantConnection(serviceName, options.grantToken);\r\n    }\r\n\r\n    const service = await this.get(serviceName);\r\n    if (!service) {\r\n      throw new Error(`Service \"${serviceName}\" not found`);\r\n    }\r\n\r\n    const port = service.tunnelPort || service.targetPort;\r\n    const host = 'localhost';\r\n\r\n    let connectionString = '';\r\n    let envVar = 'SERVICE_URL';\r\n\r\n    if (service.targetPort === 5432 || service.protocol === 'postgres') {\r\n      connectionString = `postgres://${host}:${port}/postgres`;\r\n      envVar = 'DATABASE_URL';\r\n    } else if (service.targetPort === 3306 || service.protocol === 'mysql') {\r\n      connectionString = `mysql://${host}:${port}`;\r\n      envVar = 'DATABASE_URL';\r\n    } else if (service.targetPort === 6379 || service.protocol === 'redis') {\r\n      connectionString = `redis://${host}:${port}`;\r\n      envVar = 'REDIS_URL';\r\n    } else if (service.targetPort === 27017 || service.protocol === 'mongodb') {\r\n      connectionString = `mongodb://${host}:${port}`;\r\n      envVar = 'MONGODB_URI';\r\n    } else if (service.protocol === 'http' || service.protocol === 'https') {\r\n      connectionString = `http://${host}:${port}`;\r\n      envVar = 'API_URL';\r\n    } else {\r\n      connectionString = `tcp://${host}:${port}`;\r\n      envVar = `${serviceName.toUpperCase().replace(/-/g, '_')}_URL`;\r\n    }\r\n\r\n    return { service: serviceName, host, port, connectionString, envVar };\r\n  }\r\n\r\n  private getGrantConnection(serviceName: string, grantToken: string): Connection {\r\n    const hubUrl = this.client.hubUrl;\r\n    const grantEndpoint = `${hubUrl}/grant/${encodeURIComponent(serviceName)}`;\r\n\r\n    return {\r\n      service: serviceName,\r\n      host: new URL(hubUrl).hostname,\r\n      port: new URL(hubUrl).port ? parseInt(new URL(hubUrl).port, 10) : 443,\r\n      connectionString: grantEndpoint,\r\n      envVar: 'GRANT_URL',\r\n      grantToken,\r\n      grantEndpoint,\r\n    };\r\n  }\r\n}\r\n\r\n// ─────────────────────────────────────────────────────────────────────────────\r\n// Grants API\r\n// ─────────────────────────────────────────────────────────────────────────────\r\n\r\nexport class GrantsAPI {\r\n  constructor(private client: PrivateConnect) {}\r\n\r\n  /**\r\n   * Create a time-limited access grant for an AI agent or external consumer.\r\n   */\r\n  async create(options: GrantCreateOptions): Promise<Grant> {\r\n    const response = await this.client.fetch('/v1/grants', {\r\n      method: 'POST',\r\n      body: JSON.stringify(options),\r\n    });\r\n    const data = await response.json();\r\n    return data.grant;\r\n  }\r\n\r\n  /**\r\n   * List active grants in the workspace.\r\n   */\r\n  async list(options?: { includeExpired?: boolean }): Promise<Grant[]> {\r\n    const params = new URLSearchParams();\r\n    if (options?.includeExpired) params.set('includeExpired', 'true');\r\n    const response = await this.client.fetch(`/v1/grants?${params}`);\r\n    const data = await response.json();\r\n    return data.grants || [];\r\n  }\r\n\r\n  /**\r\n   * Revoke an active grant immediately.\r\n   */\r\n  async revoke(grantId: string): Promise<void> {\r\n    await this.client.fetch(`/v1/grants/${grantId}`, { method: 'DELETE' });\r\n  }\r\n\r\n  /**\r\n   * Validate a grant token (public endpoint — no API key required).\r\n   * Returns the grant if valid, null otherwise.\r\n   */\r\n  async validate(token: string): Promise<Grant | null> {\r\n    try {\r\n      const url = `${this.client.hubUrl}/v1/grants/validate`;\r\n      const response = await fetch(url, {\r\n        method: 'POST',\r\n        headers: { 'Content-Type': 'application/json' },\r\n        body: JSON.stringify({ token }),\r\n      });\r\n      if (!response.ok) return null;\r\n      const data = await response.json();\r\n      return data.valid ? data.grant : null;\r\n    } catch {\r\n      return null;\r\n    }\r\n  }\r\n}\r\n\r\n// ─────────────────────────────────────────────────────────────────────────────\r\n// Main Client\r\n// ─────────────────────────────────────────────────────────────────────────────\r\n\r\nexport class PrivateConnect {\r\n  private config: { apiKey: string; hubUrl: string; agentId?: string };\r\n\r\n  /** Agents API for discovery and orchestration */\r\n  public agents: AgentsAPI;\r\n\r\n  /** Services API for connecting to services */\r\n  public services: ServicesAPI;\r\n\r\n  /** Grants API for managing scoped access tokens (time-limited or persistent) */\r\n  public grants: GrantsAPI;\r\n\r\n  constructor(config: PrivateConnectConfig) {\r\n    this.config = {\r\n      apiKey: config.apiKey,\r\n      hubUrl: config.hubUrl || 'https://api.privateconnect.co',\r\n      agentId: config.agentId || detectAgentId(),\r\n    };\r\n\r\n    this.agents = new AgentsAPI(this);\r\n    this.services = new ServicesAPI(this);\r\n    this.grants = new GrantsAPI(this);\r\n\r\n    if (!config.disableTracking) {\r\n      trackSdkUsage(this.config.hubUrl);\r\n    }\r\n  }\r\n\r\n  /** The resolved agent ID, or undefined if not configured. */\r\n  get agentId(): string | undefined {\r\n    return this.config.agentId;\r\n  }\r\n\r\n  /** The hub URL this client is connected to. */\r\n  get hubUrl(): string {\r\n    return this.config.hubUrl;\r\n  }\r\n\r\n  /**\r\n   * Shorthand: get connection details for a service.\r\n   * Pass `grantToken` to connect via the grant proxy instead of a local tunnel.\r\n   */\r\n  async connect(serviceName: string, options?: { grantToken?: string }): Promise<Connection> {\r\n    return this.services.getConnection(serviceName, options);\r\n  }\r\n\r\n  /**\r\n   * Returns the agent ID or throws if not configured.\r\n   * Used by APIs that require an authenticated agent identity.\r\n   */\r\n  requireAgentId(): string {\r\n    if (!this.config.agentId) {\r\n      throw new Error(\r\n        'Agent ID not found. Either:\\n' +\r\n        '  1. Run \"connect up\" to register this machine, or\\n' +\r\n        '  2. Set PRIVATECONNECT_AGENT_ID environment variable, or\\n' +\r\n        '  3. Pass agentId in the PrivateConnect constructor.'\r\n      );\r\n    }\r\n    return this.config.agentId;\r\n  }\r\n\r\n  /** Internal fetch with API key auth. */\r\n  async fetch(path: string, options?: RequestInit): Promise<Response> {\r\n    const url = `${this.config.hubUrl}${path}`;\r\n    const response = await fetch(url, {\r\n      ...options,\r\n      headers: {\r\n        'x-api-key': this.config.apiKey,\r\n        'Content-Type': 'application/json',\r\n        ...options?.headers,\r\n      },\r\n    });\r\n\r\n    if (!response.ok) {\r\n      const error = await response.json().catch(() => ({ message: 'Unknown error' }));\r\n      throw new Error(error.message || `Request failed: ${response.status}`);\r\n    }\r\n\r\n    return response;\r\n  }\r\n}\r\n\r\nexport default PrivateConnect;\r\n\r\n/** Convenience function for quick one-off connections. */\r\nexport async function connect(\r\n  serviceName: string,\r\n  config?: PrivateConnectConfig & { grantToken?: string },\r\n): Promise<Connection> {\r\n  const apiKey = config?.apiKey || process.env.PRIVATECONNECT_API_KEY;\r\n  if (!apiKey) {\r\n    throw new Error('API key required. Set PRIVATECONNECT_API_KEY or pass config.apiKey');\r\n  }\r\n\r\n  const client = new PrivateConnect({ ...config, apiKey });\r\n  return client.connect(serviceName, { grantToken: config?.grantToken });\r\n}\r\n"]}
|
package/package.json
CHANGED
|
@@ -1,33 +1,33 @@
|
|
|
1
|
-
{
|
|
2
|
-
"name": "@privateconnect/sdk",
|
|
3
|
-
"version": "0.7.
|
|
4
|
-
"description": "TypeScript SDK for Private Connect - programmatic access to services and agent orchestration",
|
|
5
|
-
"main": "dist/index.js",
|
|
6
|
-
"types": "dist/index.d.ts",
|
|
7
|
-
"files": [
|
|
8
|
-
"dist"
|
|
9
|
-
],
|
|
10
|
-
"scripts": {
|
|
11
|
-
"build": "tsc",
|
|
12
|
-
"dev": "tsc -w",
|
|
13
|
-
"clean": "rm -rf dist"
|
|
14
|
-
},
|
|
15
|
-
"keywords": [
|
|
16
|
-
"private-connect",
|
|
17
|
-
"tunnel",
|
|
18
|
-
"networking",
|
|
19
|
-
"orchestration",
|
|
20
|
-
"agent"
|
|
21
|
-
],
|
|
22
|
-
"license": "FSL-1.1-MIT",
|
|
23
|
-
"repository": {
|
|
24
|
-
"type": "git",
|
|
25
|
-
"url": "git+https://github.com/treadiehq/private-connect.git",
|
|
26
|
-
"directory": "packages/sdk"
|
|
27
|
-
},
|
|
28
|
-
"devDependencies": {
|
|
29
|
-
"@types/node": "^20.0.0",
|
|
30
|
-
"typescript": "^5.0.0"
|
|
31
|
-
}
|
|
32
|
-
}
|
|
33
|
-
|
|
1
|
+
{
|
|
2
|
+
"name": "@privateconnect/sdk",
|
|
3
|
+
"version": "0.7.5",
|
|
4
|
+
"description": "TypeScript SDK for Private Connect - programmatic access to services and agent orchestration",
|
|
5
|
+
"main": "dist/index.js",
|
|
6
|
+
"types": "dist/index.d.ts",
|
|
7
|
+
"files": [
|
|
8
|
+
"dist"
|
|
9
|
+
],
|
|
10
|
+
"scripts": {
|
|
11
|
+
"build": "tsc",
|
|
12
|
+
"dev": "tsc -w",
|
|
13
|
+
"clean": "rm -rf dist"
|
|
14
|
+
},
|
|
15
|
+
"keywords": [
|
|
16
|
+
"private-connect",
|
|
17
|
+
"tunnel",
|
|
18
|
+
"networking",
|
|
19
|
+
"orchestration",
|
|
20
|
+
"agent"
|
|
21
|
+
],
|
|
22
|
+
"license": "FSL-1.1-MIT",
|
|
23
|
+
"repository": {
|
|
24
|
+
"type": "git",
|
|
25
|
+
"url": "git+https://github.com/treadiehq/private-connect.git",
|
|
26
|
+
"directory": "packages/sdk"
|
|
27
|
+
},
|
|
28
|
+
"devDependencies": {
|
|
29
|
+
"@types/node": "^20.0.0",
|
|
30
|
+
"typescript": "^5.0.0"
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
|