@aws/nx-plugin 0.90.0 → 0.91.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/generators.json +8 -0
- package/package.json +1 -1
- package/src/connection/generator.d.ts +2 -2
- package/src/connection/generator.js +19 -16
- package/src/connection/generator.js.map +1 -1
- package/src/mcp-server/generator-info.d.ts +8 -4
- package/src/mcp-server/generator-info.js +63 -15
- package/src/mcp-server/generator-info.js.map +1 -1
- package/src/preset/__snapshots__/generator.spec.ts.snap +1 -3
- package/src/ts/nx-generator/generator.d.ts +1 -1
- package/src/ts/react-website/runtime-config/__snapshots__/generator.spec.ts.snap +3 -1
- package/src/ts/react-website/runtime-config/files/app/components/RuntimeConfig/index.tsx.template +1 -1
- package/src/ts/strands-agent/react-connection/__snapshots__/generator.spec.ts.snap +376 -0
- package/src/ts/strands-agent/react-connection/files/src/components/__agentNameClassName__AgentClientProvider.tsx.template +117 -0
- package/src/ts/strands-agent/react-connection/files/src/hooks/use__agentNameClassName__Agent.tsx.template +18 -0
- package/src/ts/strands-agent/react-connection/generator.d.ts +10 -0
- package/src/ts/strands-agent/react-connection/generator.js +129 -0
- package/src/ts/strands-agent/react-connection/generator.js.map +1 -0
- package/src/ts/strands-agent/react-connection/schema.d.ts +15 -0
- package/src/ts/strands-agent/react-connection/schema.json +26 -0
- package/src/ts/strands-agent/react-connection/serve-local.d.ts +17 -0
- package/src/ts/strands-agent/react-connection/serve-local.js +45 -0
- package/src/ts/strands-agent/react-connection/serve-local.js.map +1 -0
- package/src/utils/ast.d.ts +3 -23
- package/src/utils/ast.js +21 -152
- package/src/utils/ast.js.map +1 -1
- package/src/utils/commands.d.ts +33 -0
- package/src/utils/commands.js +55 -0
- package/src/utils/commands.js.map +1 -0
- package/src/utils/config/__snapshots__/utils.spec.ts.snap +88 -0
- package/src/utils/config/utils.d.ts +2 -1
- package/src/utils/config/utils.js +47 -29
- package/src/utils/config/utils.js.map +1 -1
- package/src/utils/generators.d.ts +13 -0
- package/src/utils/generators.js +26 -0
- package/src/utils/generators.js.map +1 -0
- package/src/utils/nx.d.ts +4 -10
- package/src/utils/nx.js +5 -19
- package/src/utils/nx.js.map +1 -1
- package/src/utils/pkg-manager.d.ts +2 -22
- package/src/utils/pkg-manager.js +2 -7
- package/src/utils/pkg-manager.js.map +1 -1
|
@@ -0,0 +1,376 @@
|
|
|
1
|
+
// Vitest Snapshot v1, https://vitest.dev/guide/snapshot.html
|
|
2
|
+
|
|
3
|
+
exports[`ts strands agent react connection generator > should generate strands agent react connection files > TestAgentAgentClientProvider.tsx 1`] = `
|
|
4
|
+
"import type { AppRouter } from 'agent-project/src/agent/router.js';
|
|
5
|
+
import { useQueryClient } from '@tanstack/react-query';
|
|
6
|
+
import { createTRPCOptionsProxy } from '@trpc/tanstack-react-query';
|
|
7
|
+
import { createContext, FC, PropsWithChildren, useMemo } from 'react';
|
|
8
|
+
import { useRuntimeConfig } from '../hooks/useRuntimeConfig';
|
|
9
|
+
import {
|
|
10
|
+
TRPCClient,
|
|
11
|
+
createTRPCClient,
|
|
12
|
+
createWSClient,
|
|
13
|
+
wsLink,
|
|
14
|
+
} from '@trpc/client';
|
|
15
|
+
import { useSigV4 } from '../hooks/useSigV4';
|
|
16
|
+
|
|
17
|
+
/**
|
|
18
|
+
* Build a WebSocket URL from a Bedrock AgentCore Runtime ARN
|
|
19
|
+
*/
|
|
20
|
+
function buildAgentCoreWsUrl(agentRuntimeArn: string): string {
|
|
21
|
+
const region = agentRuntimeArn.split(':')[3];
|
|
22
|
+
return \`wss://bedrock-agentcore.\${region}.amazonaws.com/runtimes/\${encodeURIComponent(agentRuntimeArn)}/ws\`;
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
export interface TestAgentAgentTRPCContextValue {
|
|
26
|
+
optionsProxy: ReturnType<typeof createTRPCOptionsProxy<AppRouter>>;
|
|
27
|
+
client: TRPCClient<AppRouter>;
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
export const TestAgentAgentTRPCContext =
|
|
31
|
+
createContext<TestAgentAgentTRPCContextValue | null>(null);
|
|
32
|
+
|
|
33
|
+
export const TestAgentAgentClientProvider: FC<PropsWithChildren> = ({
|
|
34
|
+
children,
|
|
35
|
+
}) => {
|
|
36
|
+
const queryClient = useQueryClient();
|
|
37
|
+
const runtimeConfig = useRuntimeConfig();
|
|
38
|
+
const agentRuntimeValue = runtimeConfig.agentRuntimes.TestAgent;
|
|
39
|
+
const sigv4Client = useSigV4();
|
|
40
|
+
|
|
41
|
+
const container = useMemo<TestAgentAgentTRPCContextValue>(() => {
|
|
42
|
+
// If the value is an ARN, convert it to a WebSocket URL
|
|
43
|
+
const wsUrl = agentRuntimeValue.startsWith('arn:')
|
|
44
|
+
? buildAgentCoreWsUrl(agentRuntimeValue)
|
|
45
|
+
: agentRuntimeValue;
|
|
46
|
+
|
|
47
|
+
const wsClient = createWSClient({
|
|
48
|
+
url: async () => {
|
|
49
|
+
const signedRequest = await sigv4Client.sign(wsUrl, {
|
|
50
|
+
method: 'GET',
|
|
51
|
+
aws: { signQuery: true },
|
|
52
|
+
});
|
|
53
|
+
return signedRequest.url;
|
|
54
|
+
},
|
|
55
|
+
});
|
|
56
|
+
|
|
57
|
+
const client = createTRPCClient<AppRouter>({
|
|
58
|
+
links: [wsLink({ client: wsClient })],
|
|
59
|
+
});
|
|
60
|
+
|
|
61
|
+
const optionsProxy = createTRPCOptionsProxy<AppRouter>({
|
|
62
|
+
client,
|
|
63
|
+
queryClient,
|
|
64
|
+
});
|
|
65
|
+
|
|
66
|
+
return { optionsProxy, client };
|
|
67
|
+
}, [agentRuntimeValue, queryClient, sigv4Client]);
|
|
68
|
+
|
|
69
|
+
return (
|
|
70
|
+
<TestAgentAgentTRPCContext.Provider value={container}>
|
|
71
|
+
{children}
|
|
72
|
+
</TestAgentAgentTRPCContext.Provider>
|
|
73
|
+
);
|
|
74
|
+
};
|
|
75
|
+
|
|
76
|
+
export default TestAgentAgentClientProvider;
|
|
77
|
+
"
|
|
78
|
+
`;
|
|
79
|
+
|
|
80
|
+
exports[`ts strands agent react connection generator > should generate strands agent react connection files > useTestAgentAgent.tsx 1`] = `
|
|
81
|
+
"import { useContext } from 'react';
|
|
82
|
+
import {
|
|
83
|
+
TestAgentAgentTRPCContext,
|
|
84
|
+
type TestAgentAgentTRPCContextValue,
|
|
85
|
+
} from '../components/TestAgentAgentClientProvider';
|
|
86
|
+
|
|
87
|
+
export const useTestAgentAgent =
|
|
88
|
+
(): TestAgentAgentTRPCContextValue['optionsProxy'] => {
|
|
89
|
+
const container = useContext(TestAgentAgentTRPCContext);
|
|
90
|
+
if (!container) {
|
|
91
|
+
throw new Error(
|
|
92
|
+
'useTestAgentAgent must be used within TestAgentAgentClientProvider',
|
|
93
|
+
);
|
|
94
|
+
}
|
|
95
|
+
return container.optionsProxy;
|
|
96
|
+
};
|
|
97
|
+
|
|
98
|
+
export const useTestAgentAgentClient =
|
|
99
|
+
(): TestAgentAgentTRPCContextValue['client'] => {
|
|
100
|
+
const container = useContext(TestAgentAgentTRPCContext);
|
|
101
|
+
if (!container) {
|
|
102
|
+
throw new Error(
|
|
103
|
+
'useTestAgentAgentClient must be used within TestAgentAgentClientProvider',
|
|
104
|
+
);
|
|
105
|
+
}
|
|
106
|
+
return container.client;
|
|
107
|
+
};
|
|
108
|
+
"
|
|
109
|
+
`;
|
|
110
|
+
|
|
111
|
+
exports[`ts strands agent react connection generator > should handle Cognito auth option > TestAgentAgentClientProvider-Cognito.tsx 1`] = `
|
|
112
|
+
"import type { AppRouter } from 'agent-project/src/agent/router.js';
|
|
113
|
+
import { useQueryClient } from '@tanstack/react-query';
|
|
114
|
+
import { createTRPCOptionsProxy } from '@trpc/tanstack-react-query';
|
|
115
|
+
import { createContext, FC, PropsWithChildren, useMemo } from 'react';
|
|
116
|
+
import { useRuntimeConfig } from '../hooks/useRuntimeConfig';
|
|
117
|
+
import {
|
|
118
|
+
TRPCClient,
|
|
119
|
+
createTRPCClient,
|
|
120
|
+
createWSClient,
|
|
121
|
+
wsLink,
|
|
122
|
+
} from '@trpc/client';
|
|
123
|
+
import { useAuth } from 'react-oidc-context';
|
|
124
|
+
|
|
125
|
+
/**
|
|
126
|
+
* Utility to base64url-encode a string (for JWT in WebSocket protocol header)
|
|
127
|
+
*/
|
|
128
|
+
function base64UrlEncode(str: string): string {
|
|
129
|
+
return btoa(str).replace(/\\+/g, '-').replace(/\\//g, '_').replace(/=/g, '');
|
|
130
|
+
}
|
|
131
|
+
|
|
132
|
+
/**
|
|
133
|
+
* Build a WebSocket URL from a Bedrock AgentCore Runtime ARN
|
|
134
|
+
*/
|
|
135
|
+
function buildAgentCoreWsUrl(agentRuntimeArn: string): string {
|
|
136
|
+
const region = agentRuntimeArn.split(':')[3];
|
|
137
|
+
return \`wss://bedrock-agentcore.\${region}.amazonaws.com/runtimes/\${encodeURIComponent(agentRuntimeArn)}/ws\`;
|
|
138
|
+
}
|
|
139
|
+
|
|
140
|
+
export interface TestAgentAgentTRPCContextValue {
|
|
141
|
+
optionsProxy: ReturnType<typeof createTRPCOptionsProxy<AppRouter>>;
|
|
142
|
+
client: TRPCClient<AppRouter>;
|
|
143
|
+
}
|
|
144
|
+
|
|
145
|
+
export const TestAgentAgentTRPCContext =
|
|
146
|
+
createContext<TestAgentAgentTRPCContextValue | null>(null);
|
|
147
|
+
|
|
148
|
+
export const TestAgentAgentClientProvider: FC<PropsWithChildren> = ({
|
|
149
|
+
children,
|
|
150
|
+
}) => {
|
|
151
|
+
const queryClient = useQueryClient();
|
|
152
|
+
const runtimeConfig = useRuntimeConfig();
|
|
153
|
+
const agentRuntimeValue = runtimeConfig.agentRuntimes.TestAgent;
|
|
154
|
+
const auth = useAuth();
|
|
155
|
+
const accessToken = auth?.user?.access_token;
|
|
156
|
+
|
|
157
|
+
const container = useMemo<TestAgentAgentTRPCContextValue>(() => {
|
|
158
|
+
// If the value is an ARN, convert it to a WebSocket URL
|
|
159
|
+
const wsUrl = agentRuntimeValue.startsWith('arn:')
|
|
160
|
+
? buildAgentCoreWsUrl(agentRuntimeValue)
|
|
161
|
+
: agentRuntimeValue;
|
|
162
|
+
|
|
163
|
+
const wsClient = createWSClient({
|
|
164
|
+
url: wsUrl,
|
|
165
|
+
WebSocket: class extends WebSocket {
|
|
166
|
+
constructor(url: string | URL, protocols?: string | string[]) {
|
|
167
|
+
const existingProtocols = protocols
|
|
168
|
+
? Array.isArray(protocols)
|
|
169
|
+
? protocols
|
|
170
|
+
: [protocols]
|
|
171
|
+
: [];
|
|
172
|
+
if (accessToken) {
|
|
173
|
+
const base64Token = base64UrlEncode(accessToken);
|
|
174
|
+
super(url, [
|
|
175
|
+
...existingProtocols,
|
|
176
|
+
\`base64UrlBearerAuthorization.\${base64Token}\`,
|
|
177
|
+
'base64UrlBearerAuthorization',
|
|
178
|
+
]);
|
|
179
|
+
} else {
|
|
180
|
+
super(url, existingProtocols);
|
|
181
|
+
}
|
|
182
|
+
}
|
|
183
|
+
},
|
|
184
|
+
});
|
|
185
|
+
|
|
186
|
+
const client = createTRPCClient<AppRouter>({
|
|
187
|
+
links: [wsLink({ client: wsClient })],
|
|
188
|
+
});
|
|
189
|
+
|
|
190
|
+
const optionsProxy = createTRPCOptionsProxy<AppRouter>({
|
|
191
|
+
client,
|
|
192
|
+
queryClient,
|
|
193
|
+
});
|
|
194
|
+
|
|
195
|
+
return { optionsProxy, client };
|
|
196
|
+
}, [agentRuntimeValue, queryClient, accessToken]);
|
|
197
|
+
|
|
198
|
+
return (
|
|
199
|
+
<TestAgentAgentTRPCContext.Provider value={container}>
|
|
200
|
+
{children}
|
|
201
|
+
</TestAgentAgentTRPCContext.Provider>
|
|
202
|
+
);
|
|
203
|
+
};
|
|
204
|
+
|
|
205
|
+
export default TestAgentAgentClientProvider;
|
|
206
|
+
"
|
|
207
|
+
`;
|
|
208
|
+
|
|
209
|
+
exports[`ts strands agent react connection generator > should handle IAM auth option > TestAgentAgentClientProvider-IAM.tsx 1`] = `
|
|
210
|
+
"import type { AppRouter } from 'agent-project/src/agent/router.js';
|
|
211
|
+
import { useQueryClient } from '@tanstack/react-query';
|
|
212
|
+
import { createTRPCOptionsProxy } from '@trpc/tanstack-react-query';
|
|
213
|
+
import { createContext, FC, PropsWithChildren, useMemo } from 'react';
|
|
214
|
+
import { useRuntimeConfig } from '../hooks/useRuntimeConfig';
|
|
215
|
+
import {
|
|
216
|
+
TRPCClient,
|
|
217
|
+
createTRPCClient,
|
|
218
|
+
createWSClient,
|
|
219
|
+
wsLink,
|
|
220
|
+
} from '@trpc/client';
|
|
221
|
+
import { useSigV4 } from '../hooks/useSigV4';
|
|
222
|
+
|
|
223
|
+
/**
|
|
224
|
+
* Build a WebSocket URL from a Bedrock AgentCore Runtime ARN
|
|
225
|
+
*/
|
|
226
|
+
function buildAgentCoreWsUrl(agentRuntimeArn: string): string {
|
|
227
|
+
const region = agentRuntimeArn.split(':')[3];
|
|
228
|
+
return \`wss://bedrock-agentcore.\${region}.amazonaws.com/runtimes/\${encodeURIComponent(agentRuntimeArn)}/ws\`;
|
|
229
|
+
}
|
|
230
|
+
|
|
231
|
+
export interface TestAgentAgentTRPCContextValue {
|
|
232
|
+
optionsProxy: ReturnType<typeof createTRPCOptionsProxy<AppRouter>>;
|
|
233
|
+
client: TRPCClient<AppRouter>;
|
|
234
|
+
}
|
|
235
|
+
|
|
236
|
+
export const TestAgentAgentTRPCContext =
|
|
237
|
+
createContext<TestAgentAgentTRPCContextValue | null>(null);
|
|
238
|
+
|
|
239
|
+
export const TestAgentAgentClientProvider: FC<PropsWithChildren> = ({
|
|
240
|
+
children,
|
|
241
|
+
}) => {
|
|
242
|
+
const queryClient = useQueryClient();
|
|
243
|
+
const runtimeConfig = useRuntimeConfig();
|
|
244
|
+
const agentRuntimeValue = runtimeConfig.agentRuntimes.TestAgent;
|
|
245
|
+
const sigv4Client = useSigV4();
|
|
246
|
+
|
|
247
|
+
const container = useMemo<TestAgentAgentTRPCContextValue>(() => {
|
|
248
|
+
// If the value is an ARN, convert it to a WebSocket URL
|
|
249
|
+
const wsUrl = agentRuntimeValue.startsWith('arn:')
|
|
250
|
+
? buildAgentCoreWsUrl(agentRuntimeValue)
|
|
251
|
+
: agentRuntimeValue;
|
|
252
|
+
|
|
253
|
+
const wsClient = createWSClient({
|
|
254
|
+
url: async () => {
|
|
255
|
+
const signedRequest = await sigv4Client.sign(wsUrl, {
|
|
256
|
+
method: 'GET',
|
|
257
|
+
aws: { signQuery: true },
|
|
258
|
+
});
|
|
259
|
+
return signedRequest.url;
|
|
260
|
+
},
|
|
261
|
+
});
|
|
262
|
+
|
|
263
|
+
const client = createTRPCClient<AppRouter>({
|
|
264
|
+
links: [wsLink({ client: wsClient })],
|
|
265
|
+
});
|
|
266
|
+
|
|
267
|
+
const optionsProxy = createTRPCOptionsProxy<AppRouter>({
|
|
268
|
+
client,
|
|
269
|
+
queryClient,
|
|
270
|
+
});
|
|
271
|
+
|
|
272
|
+
return { optionsProxy, client };
|
|
273
|
+
}, [agentRuntimeValue, queryClient, sigv4Client]);
|
|
274
|
+
|
|
275
|
+
return (
|
|
276
|
+
<TestAgentAgentTRPCContext.Provider value={container}>
|
|
277
|
+
{children}
|
|
278
|
+
</TestAgentAgentTRPCContext.Provider>
|
|
279
|
+
);
|
|
280
|
+
};
|
|
281
|
+
|
|
282
|
+
export default TestAgentAgentClientProvider;
|
|
283
|
+
"
|
|
284
|
+
`;
|
|
285
|
+
|
|
286
|
+
exports[`ts strands agent react connection generator > should handle no auth option > TestAgentAgentClientProvider-NoAuth.tsx 1`] = `
|
|
287
|
+
"import type { AppRouter } from 'agent-project/src/agent/router.js';
|
|
288
|
+
import { useQueryClient } from '@tanstack/react-query';
|
|
289
|
+
import { createTRPCOptionsProxy } from '@trpc/tanstack-react-query';
|
|
290
|
+
import { createContext, FC, PropsWithChildren, useMemo } from 'react';
|
|
291
|
+
import { useRuntimeConfig } from '../hooks/useRuntimeConfig';
|
|
292
|
+
import {
|
|
293
|
+
TRPCClient,
|
|
294
|
+
createTRPCClient,
|
|
295
|
+
createWSClient,
|
|
296
|
+
wsLink,
|
|
297
|
+
} from '@trpc/client';
|
|
298
|
+
|
|
299
|
+
/**
|
|
300
|
+
* Build a WebSocket URL from a Bedrock AgentCore Runtime ARN
|
|
301
|
+
*/
|
|
302
|
+
function buildAgentCoreWsUrl(agentRuntimeArn: string): string {
|
|
303
|
+
const region = agentRuntimeArn.split(':')[3];
|
|
304
|
+
return \`wss://bedrock-agentcore.\${region}.amazonaws.com/runtimes/\${encodeURIComponent(agentRuntimeArn)}/ws\`;
|
|
305
|
+
}
|
|
306
|
+
|
|
307
|
+
export interface TestAgentAgentTRPCContextValue {
|
|
308
|
+
optionsProxy: ReturnType<typeof createTRPCOptionsProxy<AppRouter>>;
|
|
309
|
+
client: TRPCClient<AppRouter>;
|
|
310
|
+
}
|
|
311
|
+
|
|
312
|
+
export const TestAgentAgentTRPCContext =
|
|
313
|
+
createContext<TestAgentAgentTRPCContextValue | null>(null);
|
|
314
|
+
|
|
315
|
+
export const TestAgentAgentClientProvider: FC<PropsWithChildren> = ({
|
|
316
|
+
children,
|
|
317
|
+
}) => {
|
|
318
|
+
const queryClient = useQueryClient();
|
|
319
|
+
const runtimeConfig = useRuntimeConfig();
|
|
320
|
+
const agentRuntimeValue = runtimeConfig.agentRuntimes.TestAgent;
|
|
321
|
+
|
|
322
|
+
const container = useMemo<TestAgentAgentTRPCContextValue>(() => {
|
|
323
|
+
// If the value is an ARN, convert it to a WebSocket URL
|
|
324
|
+
const wsUrl = agentRuntimeValue.startsWith('arn:')
|
|
325
|
+
? buildAgentCoreWsUrl(agentRuntimeValue)
|
|
326
|
+
: agentRuntimeValue;
|
|
327
|
+
|
|
328
|
+
const wsClient = createWSClient({
|
|
329
|
+
url: wsUrl,
|
|
330
|
+
});
|
|
331
|
+
|
|
332
|
+
const client = createTRPCClient<AppRouter>({
|
|
333
|
+
links: [wsLink({ client: wsClient })],
|
|
334
|
+
});
|
|
335
|
+
|
|
336
|
+
const optionsProxy = createTRPCOptionsProxy<AppRouter>({
|
|
337
|
+
client,
|
|
338
|
+
queryClient,
|
|
339
|
+
});
|
|
340
|
+
|
|
341
|
+
return { optionsProxy, client };
|
|
342
|
+
}, [agentRuntimeValue, queryClient]);
|
|
343
|
+
|
|
344
|
+
return (
|
|
345
|
+
<TestAgentAgentTRPCContext.Provider value={container}>
|
|
346
|
+
{children}
|
|
347
|
+
</TestAgentAgentTRPCContext.Provider>
|
|
348
|
+
);
|
|
349
|
+
};
|
|
350
|
+
|
|
351
|
+
export default TestAgentAgentClientProvider;
|
|
352
|
+
"
|
|
353
|
+
`;
|
|
354
|
+
|
|
355
|
+
exports[`ts strands agent react connection generator > should modify main.tsx correctly > main.tsx 1`] = `
|
|
356
|
+
"import TestAgentAgentClientProvider from './components/TestAgentAgentClientProvider';
|
|
357
|
+
import QueryClientProvider from './components/QueryClientProvider';
|
|
358
|
+
import RuntimeConfigProvider from './components/RuntimeConfig';
|
|
359
|
+
|
|
360
|
+
import { RouterProvider } from '@tanstack/react-router';
|
|
361
|
+
|
|
362
|
+
const App = () => <RouterProvider router={router} />;
|
|
363
|
+
|
|
364
|
+
export function Main() {
|
|
365
|
+
return (
|
|
366
|
+
<RuntimeConfigProvider>
|
|
367
|
+
<QueryClientProvider>
|
|
368
|
+
<TestAgentAgentClientProvider>
|
|
369
|
+
<App />
|
|
370
|
+
</TestAgentAgentClientProvider>
|
|
371
|
+
</QueryClientProvider>
|
|
372
|
+
</RuntimeConfigProvider>
|
|
373
|
+
);
|
|
374
|
+
}
|
|
375
|
+
"
|
|
376
|
+
`;
|
|
@@ -0,0 +1,117 @@
|
|
|
1
|
+
import type { AppRouter } from "<%- agentProjectAlias %>/<%- agentPath %>/router.js";
|
|
2
|
+
import { useQueryClient } from "@tanstack/react-query";
|
|
3
|
+
import { createTRPCOptionsProxy } from "@trpc/tanstack-react-query";
|
|
4
|
+
import { createContext, FC, PropsWithChildren, useMemo } from "react";
|
|
5
|
+
import { useRuntimeConfig } from "../hooks/useRuntimeConfig";
|
|
6
|
+
import { TRPCClient, createTRPCClient, createWSClient, wsLink } from "@trpc/client";
|
|
7
|
+
<%_ if (auth === 'IAM') { _%>
|
|
8
|
+
import { useSigV4 } from "../hooks/useSigV4";
|
|
9
|
+
<%_ } else if (auth === 'Cognito') { _%>
|
|
10
|
+
import { useAuth } from "react-oidc-context";
|
|
11
|
+
<%_ } _%>
|
|
12
|
+
<%_ if (auth === 'Cognito') { _%>
|
|
13
|
+
|
|
14
|
+
/**
|
|
15
|
+
* Utility to base64url-encode a string (for JWT in WebSocket protocol header)
|
|
16
|
+
*/
|
|
17
|
+
function base64UrlEncode(str: string): string {
|
|
18
|
+
return btoa(str)
|
|
19
|
+
.replace(/\+/g, '-')
|
|
20
|
+
.replace(/\//g, '_')
|
|
21
|
+
.replace(/=/g, '');
|
|
22
|
+
}
|
|
23
|
+
<%_ } _%>
|
|
24
|
+
|
|
25
|
+
/**
|
|
26
|
+
* Build a WebSocket URL from a Bedrock AgentCore Runtime ARN
|
|
27
|
+
*/
|
|
28
|
+
function buildAgentCoreWsUrl(agentRuntimeArn: string): string {
|
|
29
|
+
const region = agentRuntimeArn.split(':')[3];
|
|
30
|
+
return `wss://bedrock-agentcore.${region}.amazonaws.com/runtimes/${encodeURIComponent(agentRuntimeArn)}/ws`;
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
export interface <%= agentNameClassName %>AgentTRPCContextValue {
|
|
34
|
+
optionsProxy: ReturnType<typeof createTRPCOptionsProxy<AppRouter>>;
|
|
35
|
+
client: TRPCClient<AppRouter>;
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
export const <%= agentNameClassName %>AgentTRPCContext = createContext<<%= agentNameClassName %>AgentTRPCContextValue | null>(null);
|
|
39
|
+
|
|
40
|
+
export const <%= agentNameClassName %>AgentClientProvider: FC<PropsWithChildren> = ({
|
|
41
|
+
children,
|
|
42
|
+
}) => {
|
|
43
|
+
const queryClient = useQueryClient();
|
|
44
|
+
const runtimeConfig = useRuntimeConfig();
|
|
45
|
+
const agentRuntimeValue = runtimeConfig.agentRuntimes.<%= agentNameClassName %>;
|
|
46
|
+
<%_ if (auth === 'IAM') { _%>
|
|
47
|
+
const sigv4Client = useSigV4();
|
|
48
|
+
<%_ } else if (auth === 'Cognito') { _%>
|
|
49
|
+
const auth = useAuth();
|
|
50
|
+
const accessToken = auth?.user?.access_token;
|
|
51
|
+
<%_ } _%>
|
|
52
|
+
|
|
53
|
+
const container = useMemo<<%= agentNameClassName %>AgentTRPCContextValue>(() => {
|
|
54
|
+
// If the value is an ARN, convert it to a WebSocket URL
|
|
55
|
+
const wsUrl = agentRuntimeValue.startsWith('arn:')
|
|
56
|
+
? buildAgentCoreWsUrl(agentRuntimeValue)
|
|
57
|
+
: agentRuntimeValue;
|
|
58
|
+
|
|
59
|
+
<%_ if (auth === 'IAM') { _%>
|
|
60
|
+
const wsClient = createWSClient({
|
|
61
|
+
url: async () => {
|
|
62
|
+
const signedRequest = await sigv4Client.sign(wsUrl, {
|
|
63
|
+
method: 'GET',
|
|
64
|
+
aws: { signQuery: true },
|
|
65
|
+
});
|
|
66
|
+
return signedRequest.url;
|
|
67
|
+
},
|
|
68
|
+
});
|
|
69
|
+
<%_ } else if (auth === 'Cognito') { _%>
|
|
70
|
+
const wsClient = createWSClient({
|
|
71
|
+
url: wsUrl,
|
|
72
|
+
WebSocket: class extends WebSocket {
|
|
73
|
+
constructor(url: string | URL, protocols?: string | string[]) {
|
|
74
|
+
const existingProtocols = protocols
|
|
75
|
+
? Array.isArray(protocols)
|
|
76
|
+
? protocols
|
|
77
|
+
: [protocols]
|
|
78
|
+
: [];
|
|
79
|
+
if (accessToken) {
|
|
80
|
+
const base64Token = base64UrlEncode(accessToken);
|
|
81
|
+
super(url, [
|
|
82
|
+
...existingProtocols,
|
|
83
|
+
`base64UrlBearerAuthorization.${base64Token}`,
|
|
84
|
+
'base64UrlBearerAuthorization',
|
|
85
|
+
]);
|
|
86
|
+
} else {
|
|
87
|
+
super(url, existingProtocols);
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
},
|
|
91
|
+
});
|
|
92
|
+
<%_ } else { _%>
|
|
93
|
+
const wsClient = createWSClient({
|
|
94
|
+
url: wsUrl,
|
|
95
|
+
});
|
|
96
|
+
<%_ } _%>
|
|
97
|
+
|
|
98
|
+
const client = createTRPCClient<AppRouter>({
|
|
99
|
+
links: [wsLink({ client: wsClient })],
|
|
100
|
+
});
|
|
101
|
+
|
|
102
|
+
const optionsProxy = createTRPCOptionsProxy<AppRouter>({
|
|
103
|
+
client,
|
|
104
|
+
queryClient,
|
|
105
|
+
});
|
|
106
|
+
|
|
107
|
+
return { optionsProxy, client };
|
|
108
|
+
}, [agentRuntimeValue, queryClient<% if (auth === 'IAM') { %>, sigv4Client<% } else if (auth === 'Cognito') { %>, accessToken<% } %>]);
|
|
109
|
+
|
|
110
|
+
return (
|
|
111
|
+
<<%= agentNameClassName %>AgentTRPCContext.Provider value={container}>
|
|
112
|
+
{children}
|
|
113
|
+
</<%= agentNameClassName %>AgentTRPCContext.Provider>
|
|
114
|
+
);
|
|
115
|
+
};
|
|
116
|
+
|
|
117
|
+
export default <%= agentNameClassName %>AgentClientProvider;
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { useContext } from 'react';
|
|
2
|
+
import { <%= agentNameClassName %>AgentTRPCContext, type <%= agentNameClassName %>AgentTRPCContextValue } from '../components/<%- agentNameClassName %>AgentClientProvider';
|
|
3
|
+
|
|
4
|
+
export const use<%- agentNameClassName %>Agent = (): <%= agentNameClassName %>AgentTRPCContextValue['optionsProxy'] => {
|
|
5
|
+
const container = useContext(<%= agentNameClassName %>AgentTRPCContext);
|
|
6
|
+
if (!container) {
|
|
7
|
+
throw new Error('use<%- agentNameClassName %>Agent must be used within <%= agentNameClassName %>AgentClientProvider');
|
|
8
|
+
}
|
|
9
|
+
return container.optionsProxy;
|
|
10
|
+
};
|
|
11
|
+
|
|
12
|
+
export const use<%- agentNameClassName %>AgentClient = (): <%= agentNameClassName %>AgentTRPCContextValue['client'] => {
|
|
13
|
+
const container = useContext(<%= agentNameClassName %>AgentTRPCContext);
|
|
14
|
+
if (!container) {
|
|
15
|
+
throw new Error('use<%- agentNameClassName %>AgentClient must be used within <%= agentNameClassName %>AgentClientProvider');
|
|
16
|
+
}
|
|
17
|
+
return container.client;
|
|
18
|
+
};
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
|
|
3
|
+
* SPDX-License-Identifier: Apache-2.0
|
|
4
|
+
*/
|
|
5
|
+
import { Tree } from '@nx/devkit';
|
|
6
|
+
import { NxGeneratorInfo } from '../../../utils/nx';
|
|
7
|
+
import { ResolvedConnectionOptions } from '../../../connection/generator';
|
|
8
|
+
export declare const TS_STRANDS_AGENT_REACT_CONNECTION_GENERATOR_INFO: NxGeneratorInfo;
|
|
9
|
+
export declare function tsStrandsAgentReactConnectionGenerator(tree: Tree, options: ResolvedConnectionOptions): Promise<() => void>;
|
|
10
|
+
export default tsStrandsAgentReactConnectionGenerator;
|
|
@@ -0,0 +1,129 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.TS_STRANDS_AGENT_REACT_CONNECTION_GENERATOR_INFO = void 0;
|
|
4
|
+
exports.tsStrandsAgentReactConnectionGenerator = tsStrandsAgentReactConnectionGenerator;
|
|
5
|
+
/**
|
|
6
|
+
* Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
|
|
7
|
+
* SPDX-License-Identifier: Apache-2.0
|
|
8
|
+
*/
|
|
9
|
+
const devkit_1 = require("@nx/devkit");
|
|
10
|
+
const generator_1 = require("../../react-website/runtime-config/generator");
|
|
11
|
+
const npm_scope_1 = require("../../../utils/npm-scope");
|
|
12
|
+
const versions_1 = require("../../../utils/versions");
|
|
13
|
+
const ast_1 = require("../../../utils/ast");
|
|
14
|
+
const names_1 = require("../../../utils/names");
|
|
15
|
+
const format_1 = require("../../../utils/format");
|
|
16
|
+
const nx_1 = require("../../../utils/nx");
|
|
17
|
+
const metrics_1 = require("../../../utils/metrics");
|
|
18
|
+
const serve_local_1 = require("./serve-local");
|
|
19
|
+
exports.TS_STRANDS_AGENT_REACT_CONNECTION_GENERATOR_INFO = (0, nx_1.getGeneratorInfo)(__filename);
|
|
20
|
+
async function tsStrandsAgentReactConnectionGenerator(tree, options) {
|
|
21
|
+
const frontendProjectConfig = (0, nx_1.readProjectConfigurationUnqualified)(tree, options.sourceProject);
|
|
22
|
+
const agentProjectConfig = (0, nx_1.readProjectConfigurationUnqualified)(tree, options.targetProject);
|
|
23
|
+
const targetComponent = options.targetComponent;
|
|
24
|
+
// Extract agent metadata from the target component or project metadata
|
|
25
|
+
const metadata = agentProjectConfig.metadata;
|
|
26
|
+
const agentName = targetComponent?.name ?? 'agent';
|
|
27
|
+
const agentNameClassName = targetComponent?.rc ?? (0, names_1.toClassName)(agentName);
|
|
28
|
+
const agentPort = targetComponent?.port ?? metadata?.ports?.[0] ?? 8081;
|
|
29
|
+
const auth = targetComponent?.auth ?? metadata?.auth ?? 'IAM';
|
|
30
|
+
const agentProjectAlias = (0, npm_scope_1.toScopeAlias)(agentProjectConfig.name);
|
|
31
|
+
const agentPath = targetComponent?.path ?? 'src/agent';
|
|
32
|
+
// Ensure the agent project has a wildcard path entry in tsconfig.base.json
|
|
33
|
+
// so that deep imports (e.g., for the router type) resolve correctly
|
|
34
|
+
ensureWildcardPathEntry(tree, agentProjectConfig.name, agentProjectConfig.root);
|
|
35
|
+
(0, devkit_1.generateFiles)(tree, (0, devkit_1.joinPathFragments)(__dirname, 'files'), frontendProjectConfig.root, {
|
|
36
|
+
agentName,
|
|
37
|
+
agentNameClassName,
|
|
38
|
+
auth,
|
|
39
|
+
agentProjectAlias,
|
|
40
|
+
agentPath,
|
|
41
|
+
}, {
|
|
42
|
+
overwriteStrategy: devkit_1.OverwriteStrategy.KeepExisting,
|
|
43
|
+
});
|
|
44
|
+
// Generate the tanstack query provider if it does not exist already
|
|
45
|
+
(0, devkit_1.generateFiles)(tree, (0, devkit_1.joinPathFragments)(__dirname, '../../../utils/files/website/components/tanstack-query'), (0, devkit_1.joinPathFragments)(frontendProjectConfig.sourceRoot, 'components'), {}, {
|
|
46
|
+
overwriteStrategy: devkit_1.OverwriteStrategy.KeepExisting,
|
|
47
|
+
});
|
|
48
|
+
if (auth === 'IAM') {
|
|
49
|
+
(0, devkit_1.generateFiles)(tree, (0, devkit_1.joinPathFragments)(__dirname, '../../../utils/files/website/hooks/sigv4'), (0, devkit_1.joinPathFragments)(frontendProjectConfig.sourceRoot, 'hooks'), {}, {
|
|
50
|
+
overwriteStrategy: devkit_1.OverwriteStrategy.KeepExisting,
|
|
51
|
+
});
|
|
52
|
+
}
|
|
53
|
+
await (0, generator_1.runtimeConfigGenerator)(tree, {
|
|
54
|
+
project: frontendProjectConfig.name,
|
|
55
|
+
});
|
|
56
|
+
// update main.tsx
|
|
57
|
+
const mainTsxPath = (0, devkit_1.joinPathFragments)(frontendProjectConfig.sourceRoot, 'main.tsx');
|
|
58
|
+
await (0, ast_1.addSingleImport)(tree, mainTsxPath, 'QueryClientProvider', './components/QueryClientProvider');
|
|
59
|
+
const clientProviderName = `${agentNameClassName}AgentClientProvider`;
|
|
60
|
+
await (0, ast_1.addSingleImport)(tree, mainTsxPath, clientProviderName, `./components/${clientProviderName}`);
|
|
61
|
+
// Wrap <App /> in QueryClientProvider if not already present
|
|
62
|
+
if (!(await (0, ast_1.matchGritQL)(tree, mainTsxPath, '`<QueryClientProvider>$_</QueryClientProvider>`'))) {
|
|
63
|
+
await (0, ast_1.applyGritQL)(tree, mainTsxPath, '`<App />` => `<QueryClientProvider><App /></QueryClientProvider>`');
|
|
64
|
+
}
|
|
65
|
+
// Wrap <App /> in the agent client provider if not already present
|
|
66
|
+
if (!(await (0, ast_1.matchGritQL)(tree, mainTsxPath, `\`<${clientProviderName}>$_</${clientProviderName}>\``))) {
|
|
67
|
+
await (0, ast_1.applyGritQL)(tree, mainTsxPath, `\`<App />\` => \`<${clientProviderName}><App /></${clientProviderName}>\``);
|
|
68
|
+
}
|
|
69
|
+
await (0, serve_local_1.addStrandsAgentTargetToServeLocal)(tree, frontendProjectConfig.name, agentProjectConfig.name, {
|
|
70
|
+
agentName,
|
|
71
|
+
agentNameClassName,
|
|
72
|
+
port: agentPort,
|
|
73
|
+
targetComponent,
|
|
74
|
+
});
|
|
75
|
+
(0, devkit_1.addDependenciesToPackageJson)(tree, (0, versions_1.withVersions)([
|
|
76
|
+
'@trpc/client',
|
|
77
|
+
'@tanstack/react-query',
|
|
78
|
+
'@tanstack/react-query-devtools',
|
|
79
|
+
'@trpc/tanstack-react-query',
|
|
80
|
+
...(auth === 'IAM'
|
|
81
|
+
? [
|
|
82
|
+
'oidc-client-ts',
|
|
83
|
+
'aws4fetch',
|
|
84
|
+
'@aws-sdk/credential-providers',
|
|
85
|
+
'react-oidc-context',
|
|
86
|
+
]
|
|
87
|
+
: []),
|
|
88
|
+
...(auth === 'Cognito' ? ['react-oidc-context'] : []),
|
|
89
|
+
]), (0, versions_1.withVersions)(['@smithy/types']));
|
|
90
|
+
await (0, metrics_1.addGeneratorMetricsIfApplicable)(tree, [
|
|
91
|
+
exports.TS_STRANDS_AGENT_REACT_CONNECTION_GENERATOR_INFO,
|
|
92
|
+
]);
|
|
93
|
+
await (0, format_1.formatFilesInSubtree)(tree);
|
|
94
|
+
return () => {
|
|
95
|
+
(0, devkit_1.installPackagesTask)(tree);
|
|
96
|
+
};
|
|
97
|
+
}
|
|
98
|
+
exports.default = tsStrandsAgentReactConnectionGenerator;
|
|
99
|
+
/**
|
|
100
|
+
* Ensures a wildcard path entry exists in tsconfig.base.json for the given project,
|
|
101
|
+
* allowing deep imports (e.g., `:scope/project/src/agent/router.js`).
|
|
102
|
+
* Both the scope alias and npm package name forms are added.
|
|
103
|
+
*/
|
|
104
|
+
function ensureWildcardPathEntry(tree, projectName, projectRoot) {
|
|
105
|
+
const tsconfigPath = ['tsconfig.base.json', 'tsconfig.json'].find((p) => tree.exists(p));
|
|
106
|
+
if (!tsconfigPath)
|
|
107
|
+
return;
|
|
108
|
+
const wildcardValue = [`./${projectRoot}/*`];
|
|
109
|
+
const scopeAlias = (0, npm_scope_1.toScopeAlias)(projectName);
|
|
110
|
+
(0, devkit_1.updateJson)(tree, tsconfigPath, (json) => {
|
|
111
|
+
const paths = json.compilerOptions?.paths ?? {};
|
|
112
|
+
// Add wildcard for the scope alias (used by generated templates)
|
|
113
|
+
const scopeWildcardKey = `${scopeAlias}/*`;
|
|
114
|
+
if (!paths[scopeWildcardKey]) {
|
|
115
|
+
paths[scopeWildcardKey] = wildcardValue;
|
|
116
|
+
}
|
|
117
|
+
// Also add wildcard for the npm package name
|
|
118
|
+
const npmWildcardKey = `${projectName}/*`;
|
|
119
|
+
if (!paths[npmWildcardKey]) {
|
|
120
|
+
paths[npmWildcardKey] = wildcardValue;
|
|
121
|
+
}
|
|
122
|
+
json.compilerOptions = {
|
|
123
|
+
...json.compilerOptions,
|
|
124
|
+
paths,
|
|
125
|
+
};
|
|
126
|
+
return json;
|
|
127
|
+
});
|
|
128
|
+
}
|
|
129
|
+
//# sourceMappingURL=generator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"generator.js","sourceRoot":"","sources":["../../../../../../../packages/nx-plugin/src/ts/strands-agent/react-connection/generator.ts"],"names":[],"mappings":";;;AAgCA,wFAyKC;AAzMD;;;GAGG;AACH,uCAQoB;AACpB,4EAAsF;AACtF,wDAAwD;AACxD,sDAAuD;AACvD,4CAA+E;AAC/E,gDAAmD;AACnD,kDAA6D;AAC7D,0CAK2B;AAC3B,oDAAyE;AACzE,+CAAkE;AAGrD,QAAA,gDAAgD,GAC3D,IAAA,qBAAgB,EAAC,UAAU,CAAC,CAAC;AAExB,KAAK,UAAU,sCAAsC,CAC1D,IAAU,EACV,OAAkC;IAElC,MAAM,qBAAqB,GAAG,IAAA,wCAAmC,EAC/D,IAAI,EACJ,OAAO,CAAC,aAAa,CACtB,CAAC;IACF,MAAM,kBAAkB,GAAG,IAAA,wCAAmC,EAC5D,IAAI,EACJ,OAAO,CAAC,aAAa,CACtB,CAAC;IAEF,MAAM,eAAe,GACnB,OAAO,CAAC,eAAe,CAAC;IAE1B,uEAAuE;IACvE,MAAM,QAAQ,GAAG,kBAAkB,CAAC,QAAe,CAAC;IACpD,MAAM,SAAS,GAAG,eAAe,EAAE,IAAI,IAAI,OAAO,CAAC;IACnD,MAAM,kBAAkB,GAAG,eAAe,EAAE,EAAE,IAAI,IAAA,mBAAW,EAAC,SAAS,CAAC,CAAC;IACzE,MAAM,SAAS,GAAG,eAAe,EAAE,IAAI,IAAI,QAAQ,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC;IACxE,MAAM,IAAI,GAAG,eAAe,EAAE,IAAI,IAAI,QAAQ,EAAE,IAAI,IAAI,KAAK,CAAC;IAC9D,MAAM,iBAAiB,GAAG,IAAA,wBAAY,EAAC,kBAAkB,CAAC,IAAI,CAAC,CAAC;IAChE,MAAM,SAAS,GAAG,eAAe,EAAE,IAAI,IAAI,WAAW,CAAC;IAEvD,2EAA2E;IAC3E,qEAAqE;IACrE,uBAAuB,CACrB,IAAI,EACJ,kBAAkB,CAAC,IAAI,EACvB,kBAAkB,CAAC,IAAI,CACxB,CAAC;IAEF,IAAA,sBAAa,EACX,IAAI,EACJ,IAAA,0BAAiB,EAAC,SAAS,EAAE,OAAO,CAAC,EACrC,qBAAqB,CAAC,IAAI,EAC1B;QACE,SAAS;QACT,kBAAkB;QAClB,IAAI;QACJ,iBAAiB;QACjB,SAAS;KACV,EACD;QACE,iBAAiB,EAAE,0BAAiB,CAAC,YAAY;KAClD,CACF,CAAC;IAEF,oEAAoE;IACpE,IAAA,sBAAa,EACX,IAAI,EACJ,IAAA,0BAAiB,EACf,SAAS,EACT,wDAAwD,CACzD,EACD,IAAA,0BAAiB,EAAC,qBAAqB,CAAC,UAAU,EAAE,YAAY,CAAC,EACjE,EAAE,EACF;QACE,iBAAiB,EAAE,0BAAiB,CAAC,YAAY;KAClD,CACF,CAAC;IAEF,IAAI,IAAI,KAAK,KAAK,EAAE,CAAC;QACnB,IAAA,sBAAa,EACX,IAAI,EACJ,IAAA,0BAAiB,EAAC,SAAS,EAAE,0CAA0C,CAAC,EACxE,IAAA,0BAAiB,EAAC,qBAAqB,CAAC,UAAU,EAAE,OAAO,CAAC,EAC5D,EAAE,EACF;YACE,iBAAiB,EAAE,0BAAiB,CAAC,YAAY;SAClD,CACF,CAAC;IACJ,CAAC;IAED,MAAM,IAAA,kCAAsB,EAAC,IAAI,EAAE;QACjC,OAAO,EAAE,qBAAqB,CAAC,IAAI;KACpC,CAAC,CAAC;IAEH,kBAAkB;IAClB,MAAM,WAAW,GAAG,IAAA,0BAAiB,EACnC,qBAAqB,CAAC,UAAU,EAChC,UAAU,CACX,CAAC;IACF,MAAM,IAAA,qBAAe,EACnB,IAAI,EACJ,WAAW,EACX,qBAAqB,EACrB,kCAAkC,CACnC,CAAC;IAEF,MAAM,kBAAkB,GAAG,GAAG,kBAAkB,qBAAqB,CAAC;IACtE,MAAM,IAAA,qBAAe,EACnB,IAAI,EACJ,WAAW,EACX,kBAAkB,EAClB,gBAAgB,kBAAkB,EAAE,CACrC,CAAC;IAEF,6DAA6D;IAC7D,IACE,CAAC,CAAC,MAAM,IAAA,iBAAW,EACjB,IAAI,EACJ,WAAW,EACX,iDAAiD,CAClD,CAAC,EACF,CAAC;QACD,MAAM,IAAA,iBAAW,EACf,IAAI,EACJ,WAAW,EACX,mEAAmE,CACpE,CAAC;IACJ,CAAC;IAED,mEAAmE;IACnE,IACE,CAAC,CAAC,MAAM,IAAA,iBAAW,EACjB,IAAI,EACJ,WAAW,EACX,MAAM,kBAAkB,QAAQ,kBAAkB,KAAK,CACxD,CAAC,EACF,CAAC;QACD,MAAM,IAAA,iBAAW,EACf,IAAI,EACJ,WAAW,EACX,qBAAqB,kBAAkB,aAAa,kBAAkB,KAAK,CAC5E,CAAC;IACJ,CAAC;IAED,MAAM,IAAA,+CAAiC,EACrC,IAAI,EACJ,qBAAqB,CAAC,IAAI,EAC1B,kBAAkB,CAAC,IAAI,EACvB;QACE,SAAS;QACT,kBAAkB;QAClB,IAAI,EAAE,SAAS;QACf,eAAe;KAChB,CACF,CAAC;IAEF,IAAA,qCAA4B,EAC1B,IAAI,EACJ,IAAA,uBAAY,EAAC;QACX,cAAc;QACd,uBAAuB;QACvB,gCAAgC;QAChC,4BAA4B;QAC5B,GAAI,CAAC,IAAI,KAAK,KAAK;YACjB,CAAC,CAAC;gBACE,gBAAgB;gBAChB,WAAW;gBACX,+BAA+B;gBAC/B,oBAAoB;aACrB;YACH,CAAC,CAAC,EAAE,CAAS;QACf,GAAI,CAAC,IAAI,KAAK,SAAS,CAAC,CAAC,CAAC,CAAC,oBAAoB,CAAC,CAAC,CAAC,CAAC,EAAE,CAAS;KAC/D,CAAC,EACF,IAAA,uBAAY,EAAC,CAAC,eAAe,CAAC,CAAC,CAChC,CAAC;IAEF,MAAM,IAAA,yCAA+B,EAAC,IAAI,EAAE;QAC1C,wDAAgD;KACjD,CAAC,CAAC;IAEH,MAAM,IAAA,6BAAoB,EAAC,IAAI,CAAC,CAAC;IACjC,OAAO,GAAG,EAAE;QACV,IAAA,4BAAmB,EAAC,IAAI,CAAC,CAAC;IAC5B,CAAC,CAAC;AACJ,CAAC;AACD,kBAAe,sCAAsC,CAAC;AAEtD;;;;GAIG;AACH,SAAS,uBAAuB,CAC9B,IAAU,EACV,WAAmB,EACnB,WAAmB;IAEnB,MAAM,YAAY,GAAG,CAAC,oBAAoB,EAAE,eAAe,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CACtE,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CACf,CAAC;IACF,IAAI,CAAC,YAAY;QAAE,OAAO;IAE1B,MAAM,aAAa,GAAG,CAAC,KAAK,WAAW,IAAI,CAAC,CAAC;IAC7C,MAAM,UAAU,GAAG,IAAA,wBAAY,EAAC,WAAW,CAAC,CAAC;IAE7C,IAAA,mBAAU,EAAC,IAAI,EAAE,YAAY,EAAE,CAAC,IAAI,EAAE,EAAE;QACtC,MAAM,KAAK,GAAG,IAAI,CAAC,eAAe,EAAE,KAAK,IAAI,EAAE,CAAC;QAChD,iEAAiE;QACjE,MAAM,gBAAgB,GAAG,GAAG,UAAU,IAAI,CAAC;QAC3C,IAAI,CAAC,KAAK,CAAC,gBAAgB,CAAC,EAAE,CAAC;YAC7B,KAAK,CAAC,gBAAgB,CAAC,GAAG,aAAa,CAAC;QAC1C,CAAC;QACD,6CAA6C;QAC7C,MAAM,cAAc,GAAG,GAAG,WAAW,IAAI,CAAC;QAC1C,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC,EAAE,CAAC;YAC3B,KAAK,CAAC,cAAc,CAAC,GAAG,aAAa,CAAC;QACxC,CAAC;QACD,IAAI,CAAC,eAAe,GAAG;YACrB,GAAG,IAAI,CAAC,eAAe;YACvB,KAAK;SACN,CAAC;QACF,OAAO,IAAI,CAAC;IACd,CAAC,CAAC,CAAC;AACL,CAAC"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
|
|
3
|
+
* SPDX-License-Identifier: Apache-2.0
|
|
4
|
+
*/
|
|
5
|
+
import { ComponentMetadata } from '../../../utils/nx';
|
|
6
|
+
|
|
7
|
+
/**
|
|
8
|
+
* TypeScript types for options defined in schema.json
|
|
9
|
+
*/
|
|
10
|
+
export interface TsStrandsAgentReactConnectionGeneratorSchema {
|
|
11
|
+
sourceProject: string;
|
|
12
|
+
targetProject: string;
|
|
13
|
+
sourceComponent?: ComponentMetadata;
|
|
14
|
+
targetComponent?: ComponentMetadata;
|
|
15
|
+
}
|