@stateset/acp-client 1.0.0

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 ADDED
@@ -0,0 +1,160 @@
1
+ # @stateset/acp-client
2
+
3
+ Official Node.js client for the StateSet Agentic Commerce Protocol (ACP) Handler.
4
+
5
+ ## Installation
6
+
7
+ ```bash
8
+ npm install @stateset/acp-client
9
+ ```
10
+
11
+ ## Quick Start
12
+
13
+ ### HTTP Client
14
+
15
+ ```typescript
16
+ import { AcpHttpClient } from '@stateset/acp-client';
17
+
18
+ const client = new AcpHttpClient({
19
+ baseUrl: 'http://localhost:8080',
20
+ apiKey: 'your_api_key',
21
+ });
22
+
23
+ // Create a checkout session
24
+ const session = await client.createCheckoutSession({
25
+ items: [
26
+ { id: 'prod_123', quantity: 1 },
27
+ ],
28
+ });
29
+
30
+ // Update with customer info
31
+ await client.updateCheckoutSession(session.id, {
32
+ customer: {
33
+ billing_address: {
34
+ name: 'John Doe',
35
+ email: 'john@example.com',
36
+ line1: '123 Main St',
37
+ city: 'San Francisco',
38
+ region: 'CA',
39
+ postal_code: '94102',
40
+ country: 'US',
41
+ },
42
+ },
43
+ });
44
+
45
+ // Complete checkout
46
+ const result = await client.completeCheckoutSession(session.id, {
47
+ payment: { delegated_token: 'tok_xxx' },
48
+ });
49
+
50
+ console.log('Order ID:', result.order.id);
51
+ ```
52
+
53
+ ### gRPC Client
54
+
55
+ ```typescript
56
+ import { AcpGrpcClient } from '@stateset/acp-client';
57
+
58
+ const client = new AcpGrpcClient({
59
+ grpcAddress: 'localhost:50051',
60
+ apiKey: 'your_api_key',
61
+ });
62
+
63
+ await client.connect();
64
+
65
+ const session = await client.createCheckoutSession({
66
+ items: [{ id: 'prod_123', quantity: 1 }],
67
+ });
68
+
69
+ client.close();
70
+ ```
71
+
72
+ ## API Reference
73
+
74
+ ### AcpHttpClient
75
+
76
+ | Method | Description |
77
+ |--------|-------------|
78
+ | `createCheckoutSession(request)` | Create a new checkout session |
79
+ | `getCheckoutSession(sessionId)` | Get an existing session |
80
+ | `updateCheckoutSession(sessionId, request)` | Update session details |
81
+ | `completeCheckoutSession(sessionId, request)` | Complete with payment |
82
+ | `cancelCheckoutSession(sessionId)` | Cancel a session |
83
+ | `delegatePayment(request)` | Create PSP vault token |
84
+ | `healthCheck()` | Check service health |
85
+
86
+ ### AcpGrpcClient
87
+
88
+ | Method | Description |
89
+ |--------|-------------|
90
+ | `connect()` | Establish gRPC connection |
91
+ | `close()` | Close connection |
92
+ | `createCheckoutSession(request)` | Create a new checkout session |
93
+ | `getCheckoutSession(sessionId)` | Get an existing session |
94
+ | `updateCheckoutSession(request)` | Update session details |
95
+ | `completeCheckoutSession(request)` | Complete with payment |
96
+ | `cancelCheckoutSession(sessionId)` | Cancel a session |
97
+ | `delegatePayment(request)` | Create PSP vault token |
98
+
99
+ ## Configuration
100
+
101
+ ```typescript
102
+ interface AcpClientConfig {
103
+ baseUrl?: string; // HTTP base URL (default: http://localhost:8080)
104
+ grpcAddress?: string; // gRPC address (default: localhost:50051)
105
+ apiKey?: string; // API key for authentication
106
+ timeout?: number; // Request timeout in ms (default: 30000)
107
+ }
108
+ ```
109
+
110
+ ## Error Handling
111
+
112
+ ```typescript
113
+ import { AcpHttpClient, AcpApiError } from '@stateset/acp-client';
114
+
115
+ try {
116
+ await client.createCheckoutSession({ items: [] });
117
+ } catch (error) {
118
+ if (error instanceof AcpApiError) {
119
+ console.error('Type:', error.type);
120
+ console.error('Code:', error.code);
121
+ console.error('Message:', error.message);
122
+ console.error('Param:', error.param);
123
+ console.error('Status:', error.statusCode);
124
+ }
125
+ }
126
+ ```
127
+
128
+ ## Types
129
+
130
+ All TypeScript types are exported from the package:
131
+
132
+ ```typescript
133
+ import {
134
+ CheckoutSession,
135
+ CheckoutSessionStatus,
136
+ LineItem,
137
+ Money,
138
+ Customer,
139
+ Address,
140
+ Order,
141
+ // ... and more
142
+ } from '@stateset/acp-client';
143
+ ```
144
+
145
+ ## Development
146
+
147
+ ```bash
148
+ # Install dependencies
149
+ npm install
150
+
151
+ # Build
152
+ npm run build
153
+
154
+ # Build proto files (for gRPC)
155
+ npm run build:proto
156
+ ```
157
+
158
+ ## License
159
+
160
+ MIT
@@ -0,0 +1,57 @@
1
+ /**
2
+ * StateSet ACP Handler - gRPC Client
3
+ */
4
+ import * as grpc from '@grpc/grpc-js';
5
+ import { AcpClientConfig, CheckoutSession, CheckoutSessionWithOrder, CreateCheckoutSessionRequest, UpdateCheckoutSessionRequest, CompleteCheckoutSessionRequest, DelegatePaymentRequest, DelegatePaymentResponse } from './types';
6
+ export declare class AcpGrpcClient {
7
+ private client;
8
+ private address;
9
+ private apiKey;
10
+ constructor(config?: AcpClientConfig);
11
+ /**
12
+ * Initialize the gRPC client connection
13
+ */
14
+ connect(): Promise<void>;
15
+ /**
16
+ * Get metadata with authentication
17
+ */
18
+ private getMetadata;
19
+ /**
20
+ * Wrap a gRPC call in a Promise
21
+ */
22
+ private promisify;
23
+ /**
24
+ * Create a new checkout session
25
+ */
26
+ createCheckoutSession(request: CreateCheckoutSessionRequest): Promise<CheckoutSession>;
27
+ /**
28
+ * Get an existing checkout session
29
+ */
30
+ getCheckoutSession(sessionId: string): Promise<CheckoutSession>;
31
+ /**
32
+ * Update an existing checkout session
33
+ */
34
+ updateCheckoutSession(request: UpdateCheckoutSessionRequest): Promise<CheckoutSession>;
35
+ /**
36
+ * Complete a checkout session with payment
37
+ */
38
+ completeCheckoutSession(request: CompleteCheckoutSessionRequest): Promise<CheckoutSessionWithOrder>;
39
+ /**
40
+ * Cancel a checkout session
41
+ */
42
+ cancelCheckoutSession(sessionId: string): Promise<CheckoutSession>;
43
+ /**
44
+ * Delegate payment (PSP vault token)
45
+ */
46
+ delegatePayment(request: DelegatePaymentRequest): Promise<DelegatePaymentResponse>;
47
+ /**
48
+ * Close the gRPC connection
49
+ */
50
+ close(): void;
51
+ }
52
+ export declare class AcpGrpcError extends Error {
53
+ readonly code: grpc.status;
54
+ readonly details: string;
55
+ readonly metadata?: grpc.Metadata;
56
+ constructor(error: grpc.ServiceError);
57
+ }
@@ -0,0 +1,168 @@
1
+ "use strict";
2
+ /**
3
+ * StateSet ACP Handler - gRPC Client
4
+ */
5
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
6
+ if (k2 === undefined) k2 = k;
7
+ var desc = Object.getOwnPropertyDescriptor(m, k);
8
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
9
+ desc = { enumerable: true, get: function() { return m[k]; } };
10
+ }
11
+ Object.defineProperty(o, k2, desc);
12
+ }) : (function(o, m, k, k2) {
13
+ if (k2 === undefined) k2 = k;
14
+ o[k2] = m[k];
15
+ }));
16
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
17
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
18
+ }) : function(o, v) {
19
+ o["default"] = v;
20
+ });
21
+ var __importStar = (this && this.__importStar) || (function () {
22
+ var ownKeys = function(o) {
23
+ ownKeys = Object.getOwnPropertyNames || function (o) {
24
+ var ar = [];
25
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
26
+ return ar;
27
+ };
28
+ return ownKeys(o);
29
+ };
30
+ return function (mod) {
31
+ if (mod && mod.__esModule) return mod;
32
+ var result = {};
33
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
34
+ __setModuleDefault(result, mod);
35
+ return result;
36
+ };
37
+ })();
38
+ Object.defineProperty(exports, "__esModule", { value: true });
39
+ exports.AcpGrpcError = exports.AcpGrpcClient = void 0;
40
+ const grpc = __importStar(require("@grpc/grpc-js"));
41
+ const protoLoader = __importStar(require("@grpc/proto-loader"));
42
+ const path = __importStar(require("path"));
43
+ // Proto loader options
44
+ const PROTO_LOADER_OPTIONS = {
45
+ keepCase: true,
46
+ longs: String,
47
+ enums: String,
48
+ defaults: true,
49
+ oneofs: true,
50
+ };
51
+ class AcpGrpcClient {
52
+ constructor(config = {}) {
53
+ this.address = config.grpcAddress || 'localhost:50051';
54
+ this.apiKey = config.apiKey || '';
55
+ }
56
+ /**
57
+ * Initialize the gRPC client connection
58
+ */
59
+ async connect() {
60
+ const protoPath = path.join(__dirname, '..', 'proto', 'acp_handler', 'v1', 'acp_handler.proto');
61
+ const packageDefinition = await protoLoader.load(protoPath, PROTO_LOADER_OPTIONS);
62
+ const protoDescriptor = grpc.loadPackageDefinition(packageDefinition);
63
+ const AcpHandler = protoDescriptor.acp_handler.v1.AcpHandler;
64
+ const credentials = grpc.credentials.createInsecure();
65
+ this.client = new AcpHandler(this.address, credentials);
66
+ }
67
+ /**
68
+ * Get metadata with authentication
69
+ */
70
+ getMetadata() {
71
+ const metadata = new grpc.Metadata();
72
+ if (this.apiKey) {
73
+ metadata.set('authorization', `Bearer ${this.apiKey}`);
74
+ }
75
+ return metadata;
76
+ }
77
+ /**
78
+ * Wrap a gRPC call in a Promise
79
+ */
80
+ promisify(method, request) {
81
+ return new Promise((resolve, reject) => {
82
+ if (!this.client) {
83
+ reject(new Error('Client not connected. Call connect() first.'));
84
+ return;
85
+ }
86
+ this.client[method](request, this.getMetadata(), (err, response) => {
87
+ if (err) {
88
+ reject(new AcpGrpcError(err));
89
+ }
90
+ else {
91
+ resolve(response);
92
+ }
93
+ });
94
+ });
95
+ }
96
+ /**
97
+ * Create a new checkout session
98
+ */
99
+ async createCheckoutSession(request) {
100
+ return this.promisify('CreateCheckoutSession', request);
101
+ }
102
+ /**
103
+ * Get an existing checkout session
104
+ */
105
+ async getCheckoutSession(sessionId) {
106
+ return this.promisify('GetCheckoutSession', { session_id: sessionId });
107
+ }
108
+ /**
109
+ * Update an existing checkout session
110
+ */
111
+ async updateCheckoutSession(request) {
112
+ return this.promisify('UpdateCheckoutSession', request);
113
+ }
114
+ /**
115
+ * Complete a checkout session with payment
116
+ */
117
+ async completeCheckoutSession(request) {
118
+ return this.promisify('CompleteCheckoutSession', request);
119
+ }
120
+ /**
121
+ * Cancel a checkout session
122
+ */
123
+ async cancelCheckoutSession(sessionId) {
124
+ return this.promisify('CancelCheckoutSession', { session_id: sessionId });
125
+ }
126
+ /**
127
+ * Delegate payment (PSP vault token)
128
+ */
129
+ async delegatePayment(request) {
130
+ // Convert metadata object to JSON string for proto
131
+ const protoRequest = {
132
+ ...request,
133
+ metadata_json: request.metadata ? JSON.stringify(request.metadata) : '',
134
+ payment_method: {
135
+ ...request.payment_method,
136
+ metadata_json: request.payment_method.metadata
137
+ ? JSON.stringify(request.payment_method.metadata)
138
+ : '',
139
+ },
140
+ };
141
+ const response = await this.promisify('DelegatePayment', protoRequest);
142
+ // Parse metadata JSON back to object
143
+ return {
144
+ ...response,
145
+ metadata: response.metadata_json ? JSON.parse(response.metadata_json) : undefined,
146
+ };
147
+ }
148
+ /**
149
+ * Close the gRPC connection
150
+ */
151
+ close() {
152
+ if (this.client) {
153
+ grpc.closeClient(this.client);
154
+ }
155
+ }
156
+ }
157
+ exports.AcpGrpcClient = AcpGrpcClient;
158
+ class AcpGrpcError extends Error {
159
+ constructor(error) {
160
+ super(error.message);
161
+ this.name = 'AcpGrpcError';
162
+ this.code = error.code;
163
+ this.details = error.details;
164
+ this.metadata = error.metadata;
165
+ }
166
+ }
167
+ exports.AcpGrpcError = AcpGrpcError;
168
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"grpc-client.js","sourceRoot":"","sources":["../src/grpc-client.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * StateSet ACP Handler - gRPC Client\n */\n\nimport * as grpc from '@grpc/grpc-js';\nimport * as protoLoader from '@grpc/proto-loader';\nimport * as path from 'path';\nimport {\n  AcpClientConfig,\n  CheckoutSession,\n  CheckoutSessionWithOrder,\n  CreateCheckoutSessionRequest,\n  UpdateCheckoutSessionRequest,\n  CompleteCheckoutSessionRequest,\n  DelegatePaymentRequest,\n  DelegatePaymentResponse,\n} from './types';\n\n// Proto loader options\nconst PROTO_LOADER_OPTIONS: protoLoader.Options = {\n  keepCase: true,\n  longs: String,\n  enums: String,\n  defaults: true,\n  oneofs: true,\n};\n\n// Type definitions for the generated gRPC client\ninterface AcpHandlerClient {\n  CreateCheckoutSession: grpc.ClientUnaryCall;\n  GetCheckoutSession: grpc.ClientUnaryCall;\n  UpdateCheckoutSession: grpc.ClientUnaryCall;\n  CompleteCheckoutSession: grpc.ClientUnaryCall;\n  CancelCheckoutSession: grpc.ClientUnaryCall;\n  DelegatePayment: grpc.ClientUnaryCall;\n}\n\nexport class AcpGrpcClient {\n  private client: any;\n  private address: string;\n  private apiKey: string;\n\n  constructor(config: AcpClientConfig = {}) {\n    this.address = config.grpcAddress || 'localhost:50051';\n    this.apiKey = config.apiKey || '';\n  }\n\n  /**\n   * Initialize the gRPC client connection\n   */\n  async connect(): Promise<void> {\n    const protoPath = path.join(\n      __dirname,\n      '..',\n      'proto',\n      'acp_handler',\n      'v1',\n      'acp_handler.proto'\n    );\n\n    const packageDefinition = await protoLoader.load(protoPath, PROTO_LOADER_OPTIONS);\n    const protoDescriptor = grpc.loadPackageDefinition(packageDefinition) as any;\n    const AcpHandler = protoDescriptor.acp_handler.v1.AcpHandler;\n\n    const credentials = grpc.credentials.createInsecure();\n    this.client = new AcpHandler(this.address, credentials);\n  }\n\n  /**\n   * Get metadata with authentication\n   */\n  private getMetadata(): grpc.Metadata {\n    const metadata = new grpc.Metadata();\n    if (this.apiKey) {\n      metadata.set('authorization', `Bearer ${this.apiKey}`);\n    }\n    return metadata;\n  }\n\n  /**\n   * Wrap a gRPC call in a Promise\n   */\n  private promisify<TRequest, TResponse>(\n    method: string,\n    request: TRequest\n  ): Promise<TResponse> {\n    return new Promise((resolve, reject) => {\n      if (!this.client) {\n        reject(new Error('Client not connected. Call connect() first.'));\n        return;\n      }\n\n      this.client[method](request, this.getMetadata(), (err: grpc.ServiceError | null, response: TResponse) => {\n        if (err) {\n          reject(new AcpGrpcError(err));\n        } else {\n          resolve(response);\n        }\n      });\n    });\n  }\n\n  /**\n   * Create a new checkout session\n   */\n  async createCheckoutSession(\n    request: CreateCheckoutSessionRequest\n  ): Promise<CheckoutSession> {\n    return this.promisify<CreateCheckoutSessionRequest, CheckoutSession>(\n      'CreateCheckoutSession',\n      request\n    );\n  }\n\n  /**\n   * Get an existing checkout session\n   */\n  async getCheckoutSession(sessionId: string): Promise<CheckoutSession> {\n    return this.promisify<{ session_id: string }, CheckoutSession>(\n      'GetCheckoutSession',\n      { session_id: sessionId }\n    );\n  }\n\n  /**\n   * Update an existing checkout session\n   */\n  async updateCheckoutSession(\n    request: UpdateCheckoutSessionRequest\n  ): Promise<CheckoutSession> {\n    return this.promisify<UpdateCheckoutSessionRequest, CheckoutSession>(\n      'UpdateCheckoutSession',\n      request\n    );\n  }\n\n  /**\n   * Complete a checkout session with payment\n   */\n  async completeCheckoutSession(\n    request: CompleteCheckoutSessionRequest\n  ): Promise<CheckoutSessionWithOrder> {\n    return this.promisify<CompleteCheckoutSessionRequest, CheckoutSessionWithOrder>(\n      'CompleteCheckoutSession',\n      request\n    );\n  }\n\n  /**\n   * Cancel a checkout session\n   */\n  async cancelCheckoutSession(sessionId: string): Promise<CheckoutSession> {\n    return this.promisify<{ session_id: string }, CheckoutSession>(\n      'CancelCheckoutSession',\n      { session_id: sessionId }\n    );\n  }\n\n  /**\n   * Delegate payment (PSP vault token)\n   */\n  async delegatePayment(\n    request: DelegatePaymentRequest\n  ): Promise<DelegatePaymentResponse> {\n    // Convert metadata object to JSON string for proto\n    const protoRequest = {\n      ...request,\n      metadata_json: request.metadata ? JSON.stringify(request.metadata) : '',\n      payment_method: {\n        ...request.payment_method,\n        metadata_json: request.payment_method.metadata\n          ? JSON.stringify(request.payment_method.metadata)\n          : '',\n      },\n    };\n\n    const response = await this.promisify<any, any>('DelegatePayment', protoRequest);\n\n    // Parse metadata JSON back to object\n    return {\n      ...response,\n      metadata: response.metadata_json ? JSON.parse(response.metadata_json) : undefined,\n    };\n  }\n\n  /**\n   * Close the gRPC connection\n   */\n  close(): void {\n    if (this.client) {\n      grpc.closeClient(this.client);\n    }\n  }\n}\n\nexport class AcpGrpcError extends Error {\n  public readonly code: grpc.status;\n  public readonly details: string;\n  public readonly metadata?: grpc.Metadata;\n\n  constructor(error: grpc.ServiceError) {\n    super(error.message);\n    this.name = 'AcpGrpcError';\n    this.code = error.code;\n    this.details = error.details;\n    this.metadata = error.metadata;\n  }\n}\n"]}
@@ -0,0 +1,48 @@
1
+ /**
2
+ * StateSet ACP Handler - HTTP REST Client
3
+ */
4
+ import { AcpClientConfig, AcpError, CheckoutSession, CheckoutSessionWithOrder, CreateCheckoutSessionRequest, UpdateCheckoutSessionRequest, CompleteCheckoutSessionRequest, DelegatePaymentRequest, DelegatePaymentResponse } from './types';
5
+ export declare class AcpHttpClient {
6
+ private baseUrl;
7
+ private apiKey;
8
+ private timeout;
9
+ constructor(config?: AcpClientConfig);
10
+ private request;
11
+ /**
12
+ * Create a new checkout session
13
+ */
14
+ createCheckoutSession(request: CreateCheckoutSessionRequest): Promise<CheckoutSession>;
15
+ /**
16
+ * Get an existing checkout session
17
+ */
18
+ getCheckoutSession(sessionId: string): Promise<CheckoutSession>;
19
+ /**
20
+ * Update an existing checkout session
21
+ */
22
+ updateCheckoutSession(sessionId: string, request: Omit<UpdateCheckoutSessionRequest, 'session_id'>): Promise<CheckoutSession>;
23
+ /**
24
+ * Complete a checkout session with payment
25
+ */
26
+ completeCheckoutSession(sessionId: string, request: Omit<CompleteCheckoutSessionRequest, 'session_id'>): Promise<CheckoutSessionWithOrder>;
27
+ /**
28
+ * Cancel a checkout session
29
+ */
30
+ cancelCheckoutSession(sessionId: string): Promise<CheckoutSession>;
31
+ /**
32
+ * Delegate payment (PSP vault token)
33
+ */
34
+ delegatePayment(request: DelegatePaymentRequest): Promise<DelegatePaymentResponse>;
35
+ /**
36
+ * Health check
37
+ */
38
+ healthCheck(): Promise<{
39
+ status: string;
40
+ }>;
41
+ }
42
+ export declare class AcpApiError extends Error {
43
+ readonly type: string;
44
+ readonly code: string;
45
+ readonly param?: string;
46
+ readonly statusCode: number;
47
+ constructor(error: AcpError, statusCode: number);
48
+ }
@@ -0,0 +1,149 @@
1
+ "use strict";
2
+ /**
3
+ * StateSet ACP Handler - HTTP REST Client
4
+ */
5
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
6
+ if (k2 === undefined) k2 = k;
7
+ var desc = Object.getOwnPropertyDescriptor(m, k);
8
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
9
+ desc = { enumerable: true, get: function() { return m[k]; } };
10
+ }
11
+ Object.defineProperty(o, k2, desc);
12
+ }) : (function(o, m, k, k2) {
13
+ if (k2 === undefined) k2 = k;
14
+ o[k2] = m[k];
15
+ }));
16
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
17
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
18
+ }) : function(o, v) {
19
+ o["default"] = v;
20
+ });
21
+ var __importStar = (this && this.__importStar) || (function () {
22
+ var ownKeys = function(o) {
23
+ ownKeys = Object.getOwnPropertyNames || function (o) {
24
+ var ar = [];
25
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
26
+ return ar;
27
+ };
28
+ return ownKeys(o);
29
+ };
30
+ return function (mod) {
31
+ if (mod && mod.__esModule) return mod;
32
+ var result = {};
33
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
34
+ __setModuleDefault(result, mod);
35
+ return result;
36
+ };
37
+ })();
38
+ Object.defineProperty(exports, "__esModule", { value: true });
39
+ exports.AcpApiError = exports.AcpHttpClient = void 0;
40
+ const https = __importStar(require("https"));
41
+ const http = __importStar(require("http"));
42
+ class AcpHttpClient {
43
+ constructor(config = {}) {
44
+ this.baseUrl = config.baseUrl || 'http://localhost:8080';
45
+ this.apiKey = config.apiKey || '';
46
+ this.timeout = config.timeout || 30000;
47
+ }
48
+ async request(method, path, body) {
49
+ const url = new URL(path, this.baseUrl);
50
+ const isHttps = url.protocol === 'https:';
51
+ const httpModule = isHttps ? https : http;
52
+ return new Promise((resolve, reject) => {
53
+ const options = {
54
+ method,
55
+ hostname: url.hostname,
56
+ port: url.port || (isHttps ? 443 : 80),
57
+ path: url.pathname + url.search,
58
+ headers: {
59
+ 'Content-Type': 'application/json',
60
+ ...(this.apiKey && { Authorization: `Bearer ${this.apiKey}` }),
61
+ },
62
+ timeout: this.timeout,
63
+ };
64
+ const req = httpModule.request(options, (res) => {
65
+ let data = '';
66
+ res.on('data', (chunk) => (data += chunk));
67
+ res.on('end', () => {
68
+ try {
69
+ const parsed = data ? JSON.parse(data) : {};
70
+ if (res.statusCode && res.statusCode >= 400) {
71
+ const error = parsed;
72
+ reject(new AcpApiError(error, res.statusCode));
73
+ }
74
+ else {
75
+ resolve(parsed);
76
+ }
77
+ }
78
+ catch (e) {
79
+ reject(new Error(`Failed to parse response: ${data}`));
80
+ }
81
+ });
82
+ });
83
+ req.on('error', reject);
84
+ req.on('timeout', () => {
85
+ req.destroy();
86
+ reject(new Error('Request timeout'));
87
+ });
88
+ if (body) {
89
+ req.write(JSON.stringify(body));
90
+ }
91
+ req.end();
92
+ });
93
+ }
94
+ /**
95
+ * Create a new checkout session
96
+ */
97
+ async createCheckoutSession(request) {
98
+ return this.request('POST', '/checkout_sessions', request);
99
+ }
100
+ /**
101
+ * Get an existing checkout session
102
+ */
103
+ async getCheckoutSession(sessionId) {
104
+ return this.request('GET', `/checkout_sessions/${sessionId}`);
105
+ }
106
+ /**
107
+ * Update an existing checkout session
108
+ */
109
+ async updateCheckoutSession(sessionId, request) {
110
+ return this.request('POST', `/checkout_sessions/${sessionId}`, request);
111
+ }
112
+ /**
113
+ * Complete a checkout session with payment
114
+ */
115
+ async completeCheckoutSession(sessionId, request) {
116
+ return this.request('POST', `/checkout_sessions/${sessionId}/complete`, request);
117
+ }
118
+ /**
119
+ * Cancel a checkout session
120
+ */
121
+ async cancelCheckoutSession(sessionId) {
122
+ return this.request('POST', `/checkout_sessions/${sessionId}/cancel`);
123
+ }
124
+ /**
125
+ * Delegate payment (PSP vault token)
126
+ */
127
+ async delegatePayment(request) {
128
+ return this.request('POST', '/agentic_commerce/delegate_payment', request);
129
+ }
130
+ /**
131
+ * Health check
132
+ */
133
+ async healthCheck() {
134
+ return this.request('GET', '/health');
135
+ }
136
+ }
137
+ exports.AcpHttpClient = AcpHttpClient;
138
+ class AcpApiError extends Error {
139
+ constructor(error, statusCode) {
140
+ super(error.message);
141
+ this.name = 'AcpApiError';
142
+ this.type = error.type;
143
+ this.code = error.code;
144
+ this.param = error.param;
145
+ this.statusCode = statusCode;
146
+ }
147
+ }
148
+ exports.AcpApiError = AcpApiError;
149
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"http-client.js","sourceRoot":"","sources":["../src/http-client.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * StateSet ACP Handler - HTTP REST Client\n */\n\nimport * as https from 'https';\nimport * as http from 'http';\nimport {\n  AcpClientConfig,\n  AcpError,\n  CheckoutSession,\n  CheckoutSessionWithOrder,\n  CreateCheckoutSessionRequest,\n  UpdateCheckoutSessionRequest,\n  CompleteCheckoutSessionRequest,\n  DelegatePaymentRequest,\n  DelegatePaymentResponse,\n} from './types';\n\nexport class AcpHttpClient {\n  private baseUrl: string;\n  private apiKey: string;\n  private timeout: number;\n\n  constructor(config: AcpClientConfig = {}) {\n    this.baseUrl = config.baseUrl || 'http://localhost:8080';\n    this.apiKey = config.apiKey || '';\n    this.timeout = config.timeout || 30000;\n  }\n\n  private async request<T>(\n    method: string,\n    path: string,\n    body?: unknown\n  ): Promise<T> {\n    const url = new URL(path, this.baseUrl);\n    const isHttps = url.protocol === 'https:';\n    const httpModule = isHttps ? https : http;\n\n    return new Promise((resolve, reject) => {\n      const options: http.RequestOptions = {\n        method,\n        hostname: url.hostname,\n        port: url.port || (isHttps ? 443 : 80),\n        path: url.pathname + url.search,\n        headers: {\n          'Content-Type': 'application/json',\n          ...(this.apiKey && { Authorization: `Bearer ${this.apiKey}` }),\n        },\n        timeout: this.timeout,\n      };\n\n      const req = httpModule.request(options, (res) => {\n        let data = '';\n        res.on('data', (chunk) => (data += chunk));\n        res.on('end', () => {\n          try {\n            const parsed = data ? JSON.parse(data) : {};\n            if (res.statusCode && res.statusCode >= 400) {\n              const error = parsed as AcpError;\n              reject(new AcpApiError(error, res.statusCode));\n            } else {\n              resolve(parsed as T);\n            }\n          } catch (e) {\n            reject(new Error(`Failed to parse response: ${data}`));\n          }\n        });\n      });\n\n      req.on('error', reject);\n      req.on('timeout', () => {\n        req.destroy();\n        reject(new Error('Request timeout'));\n      });\n\n      if (body) {\n        req.write(JSON.stringify(body));\n      }\n      req.end();\n    });\n  }\n\n  /**\n   * Create a new checkout session\n   */\n  async createCheckoutSession(\n    request: CreateCheckoutSessionRequest\n  ): Promise<CheckoutSession> {\n    return this.request<CheckoutSession>('POST', '/checkout_sessions', request);\n  }\n\n  /**\n   * Get an existing checkout session\n   */\n  async getCheckoutSession(sessionId: string): Promise<CheckoutSession> {\n    return this.request<CheckoutSession>('GET', `/checkout_sessions/${sessionId}`);\n  }\n\n  /**\n   * Update an existing checkout session\n   */\n  async updateCheckoutSession(\n    sessionId: string,\n    request: Omit<UpdateCheckoutSessionRequest, 'session_id'>\n  ): Promise<CheckoutSession> {\n    return this.request<CheckoutSession>(\n      'POST',\n      `/checkout_sessions/${sessionId}`,\n      request\n    );\n  }\n\n  /**\n   * Complete a checkout session with payment\n   */\n  async completeCheckoutSession(\n    sessionId: string,\n    request: Omit<CompleteCheckoutSessionRequest, 'session_id'>\n  ): Promise<CheckoutSessionWithOrder> {\n    return this.request<CheckoutSessionWithOrder>(\n      'POST',\n      `/checkout_sessions/${sessionId}/complete`,\n      request\n    );\n  }\n\n  /**\n   * Cancel a checkout session\n   */\n  async cancelCheckoutSession(sessionId: string): Promise<CheckoutSession> {\n    return this.request<CheckoutSession>(\n      'POST',\n      `/checkout_sessions/${sessionId}/cancel`\n    );\n  }\n\n  /**\n   * Delegate payment (PSP vault token)\n   */\n  async delegatePayment(\n    request: DelegatePaymentRequest\n  ): Promise<DelegatePaymentResponse> {\n    return this.request<DelegatePaymentResponse>(\n      'POST',\n      '/agentic_commerce/delegate_payment',\n      request\n    );\n  }\n\n  /**\n   * Health check\n   */\n  async healthCheck(): Promise<{ status: string }> {\n    return this.request<{ status: string }>('GET', '/health');\n  }\n}\n\nexport class AcpApiError extends Error {\n  public readonly type: string;\n  public readonly code: string;\n  public readonly param?: string;\n  public readonly statusCode: number;\n\n  constructor(error: AcpError, statusCode: number) {\n    super(error.message);\n    this.name = 'AcpApiError';\n    this.type = error.type;\n    this.code = error.code;\n    this.param = error.param;\n    this.statusCode = statusCode;\n  }\n}\n"]}
@@ -0,0 +1,37 @@
1
+ /**
2
+ * StateSet ACP Handler - Node.js Client
3
+ *
4
+ * Official Node.js bindings for the StateSet Agentic Commerce Protocol Handler.
5
+ * Supports both HTTP REST and gRPC transports.
6
+ *
7
+ * @example
8
+ * ```typescript
9
+ * import { AcpHttpClient, AcpGrpcClient } from '@stateset/acp-client';
10
+ *
11
+ * // HTTP Client
12
+ * const httpClient = new AcpHttpClient({
13
+ * baseUrl: 'http://localhost:8080',
14
+ * apiKey: 'api_key_demo_123',
15
+ * });
16
+ *
17
+ * const session = await httpClient.createCheckoutSession({
18
+ * items: [{ id: 'prod_123', quantity: 1 }],
19
+ * });
20
+ *
21
+ * // gRPC Client
22
+ * const grpcClient = new AcpGrpcClient({
23
+ * grpcAddress: 'localhost:50051',
24
+ * apiKey: 'api_key_demo_123',
25
+ * });
26
+ * await grpcClient.connect();
27
+ *
28
+ * const session = await grpcClient.createCheckoutSession({
29
+ * items: [{ id: 'prod_123', quantity: 1 }],
30
+ * });
31
+ * ```
32
+ */
33
+ export { AcpHttpClient, AcpApiError } from './http-client';
34
+ export { AcpGrpcClient, AcpGrpcError } from './grpc-client';
35
+ export * from './types';
36
+ import { AcpHttpClient } from './http-client';
37
+ export default AcpHttpClient;