@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 +160 -0
- package/dist/grpc-client.d.ts +57 -0
- package/dist/grpc-client.js +168 -0
- package/dist/http-client.d.ts +48 -0
- package/dist/http-client.js +149 -0
- package/dist/index.d.ts +37 -0
- package/dist/index.js +63 -0
- package/dist/types.d.ts +197 -0
- package/dist/types.js +30 -0
- package/package.json +45 -0
- package/proto/acp_handler/v1/acp_handler.proto +232 -0
- package/proto/acp_handler.proto +232 -0
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"]}
|
package/dist/index.d.ts
ADDED
|
@@ -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;
|