@naylence/runtime 0.3.14 → 0.3.15

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.
@@ -99,13 +99,453 @@ function installProcessEnvShim() {
99
99
  installProcessEnvShim();
100
100
  // --- END ENV SHIM ---
101
101
 
102
+ /**
103
+ * AUTO-GENERATED FILE. DO NOT EDIT DIRECTLY.
104
+ * Generated by scripts/generate-factory-manifest.mjs
105
+ *
106
+ * Provides the list of runtime factory modules for registration.
107
+ */
108
+ const MODULES = [
109
+ "./connector/broadcast-channel-connector-factory.js",
110
+ "./connector/broadcast-channel-listener-factory.js",
111
+ "./connector/http-listener-factory.js",
112
+ "./connector/http-stateless-connector-factory.js",
113
+ "./connector/inpage-connector-factory.js",
114
+ "./connector/inpage-listener-factory.js",
115
+ "./connector/websocket-connector-factory.js",
116
+ "./connector/websocket-listener-factory.js",
117
+ "./delivery/at-least-once-delivery-policy-factory.js",
118
+ "./delivery/at-most-once-delivery-policy-factory.js",
119
+ "./delivery/delivery-profile-factory.js",
120
+ "./fabric/in-process-fame-fabric-factory.js",
121
+ "./node/admission/admission-profile-factory.js",
122
+ "./node/admission/direct-admission-client-factory.js",
123
+ "./node/admission/noop-admission-client-factory.js",
124
+ "./node/admission/welcome-service-client-factory.js",
125
+ "./node/default-node-identity-policy-factory.js",
126
+ "./node/node-factory.js",
127
+ "./node/node-identity-policy-profile-factory.js",
128
+ "./node/token-subject-node-identity-policy-factory.js",
129
+ "./placement/static-node-placement-strategy-factory.js",
130
+ "./security/auth/bearer-token-header-auth-injection-strategy-factory.js",
131
+ "./security/auth/default-authorizer-factory.js",
132
+ "./security/auth/jwks-jwt-token-verifier-factory.js",
133
+ "./security/auth/jwt-token-issuer-factory.js",
134
+ "./security/auth/jwt-token-verifier-factory.js",
135
+ "./security/auth/no-auth-injection-strategy-factory.js",
136
+ "./security/auth/none-token-provider-factory.js",
137
+ "./security/auth/noop-authorizer-factory.js",
138
+ "./security/auth/noop-token-issuer-factory.js",
139
+ "./security/auth/noop-token-verifier-factory.js",
140
+ "./security/auth/oauth2-authorizer-factory.js",
141
+ "./security/auth/oauth2-client-credentials-token-provider-factory.js",
142
+ "./security/auth/oauth2-pkce-token-provider-factory.js",
143
+ "./security/auth/query-param-auth-injection-strategy-factory.js",
144
+ "./security/auth/shared-secret-authorizer-factory.js",
145
+ "./security/auth/shared-secret-token-provider-factory.js",
146
+ "./security/auth/shared-secret-token-verifier-factory.js",
147
+ "./security/auth/static-token-provider-factory.js",
148
+ "./security/auth/websocket-subprotocol-auth-injection-strategy-factory.js",
149
+ "./security/credential/dev-fixed-key-credential-provider-factory.js",
150
+ "./security/credential/env-credential-provider-factory.js",
151
+ "./security/credential/none-credential-provider-factory.js",
152
+ "./security/credential/prompt-credential-provider-factory.js",
153
+ "./security/credential/secret-store-credential-provider-factory.js",
154
+ "./security/credential/session-key-credential-provider-factory.js",
155
+ "./security/credential/static-credential-provider-factory.js",
156
+ "./security/default-security-manager-factory.js",
157
+ "./security/encryption/noop-encryption-manager-factory.js",
158
+ "./security/encryption/noop-secure-channel-manager-factory.js",
159
+ "./security/keys/default-key-manager-factory.js",
160
+ "./security/keys/in-memory-key-store-factory.js",
161
+ "./security/keys/noop-key-validator-factory.js",
162
+ "./security/node-security-profile-factory.js",
163
+ "./security/policy/default-security-policy-factory.js",
164
+ "./security/policy/no-security-policy-factory.js",
165
+ "./security/signing/eddsa-envelope-signer-factory.js",
166
+ "./security/signing/eddsa-envelope-verifier-factory.js",
167
+ "./security/trust-store/noop-trust-store-provider-factory.js",
168
+ "./sentinel/capability-aware-routing-policy-factory.js",
169
+ "./sentinel/composite-routing-policy-factory.js",
170
+ "./sentinel/hybrid-path-routing-policy-factory.js",
171
+ "./sentinel/load-balancing/composite-load-balancing-strategy-factory.js",
172
+ "./sentinel/load-balancing/hrw-load-balancing-strategy-factory.js",
173
+ "./sentinel/load-balancing/load-balancing-profile-factory.js",
174
+ "./sentinel/load-balancing/random-load-balancing-strategy-factory.js",
175
+ "./sentinel/load-balancing/round-robin-load-balancing-strategy-factory.js",
176
+ "./sentinel/load-balancing/sticky-load-balancing-strategy-factory.js",
177
+ "./sentinel/routing-profile-factory.js",
178
+ "./sentinel/sentinel-factory.js",
179
+ "./sentinel/store/route-store-factory.js",
180
+ "./stickiness/simple-load-balancer-stickiness-manager-factory.js",
181
+ "./telemetry/noop-trace-emitter-factory.js",
182
+ "./telemetry/open-telemetry-trace-emitter-factory.js",
183
+ "./telemetry/trace-emitter-profile-factory.js",
184
+ "./welcome/default-welcome-service-factory.js"
185
+ ];
186
+ const MODULE_LOADERS = {
187
+ "./connector/broadcast-channel-connector-factory.js": () => Promise.resolve().then(function () { return broadcastChannelConnectorFactory; }),
188
+ "./connector/broadcast-channel-listener-factory.js": () => Promise.resolve().then(function () { return broadcastChannelListenerFactory; }),
189
+ "./connector/http-listener-factory.js": () => Promise.resolve().then(function () { return httpListenerFactory; }),
190
+ "./connector/http-stateless-connector-factory.js": () => Promise.resolve().then(function () { return httpStatelessConnectorFactory; }),
191
+ "./connector/inpage-connector-factory.js": () => Promise.resolve().then(function () { return inpageConnectorFactory; }),
192
+ "./connector/inpage-listener-factory.js": () => Promise.resolve().then(function () { return inpageListenerFactory; }),
193
+ "./connector/websocket-connector-factory.js": () => Promise.resolve().then(function () { return websocketConnectorFactory; }),
194
+ "./connector/websocket-listener-factory.js": () => Promise.resolve().then(function () { return websocketListenerFactory; }),
195
+ "./delivery/at-least-once-delivery-policy-factory.js": () => Promise.resolve().then(function () { return atLeastOnceDeliveryPolicyFactory; }),
196
+ "./delivery/at-most-once-delivery-policy-factory.js": () => Promise.resolve().then(function () { return atMostOnceDeliveryPolicyFactory; }),
197
+ "./delivery/delivery-profile-factory.js": () => Promise.resolve().then(function () { return deliveryProfileFactory; }),
198
+ "./fabric/in-process-fame-fabric-factory.js": () => Promise.resolve().then(function () { return inProcessFameFabricFactory; }),
199
+ "./node/admission/admission-profile-factory.js": () => Promise.resolve().then(function () { return admissionProfileFactory; }),
200
+ "./node/admission/direct-admission-client-factory.js": () => Promise.resolve().then(function () { return directAdmissionClientFactory; }),
201
+ "./node/admission/noop-admission-client-factory.js": () => Promise.resolve().then(function () { return noopAdmissionClientFactory; }),
202
+ "./node/admission/welcome-service-client-factory.js": () => Promise.resolve().then(function () { return welcomeServiceClientFactory; }),
203
+ "./node/default-node-identity-policy-factory.js": () => Promise.resolve().then(function () { return defaultNodeIdentityPolicyFactory; }),
204
+ "./node/node-factory.js": () => Promise.resolve().then(function () { return nodeFactory; }),
205
+ "./node/node-identity-policy-profile-factory.js": () => Promise.resolve().then(function () { return nodeIdentityPolicyProfileFactory; }),
206
+ "./node/token-subject-node-identity-policy-factory.js": () => Promise.resolve().then(function () { return tokenSubjectNodeIdentityPolicyFactory; }),
207
+ "./placement/static-node-placement-strategy-factory.js": () => Promise.resolve().then(function () { return staticNodePlacementStrategyFactory; }),
208
+ "./security/auth/bearer-token-header-auth-injection-strategy-factory.js": () => Promise.resolve().then(function () { return bearerTokenHeaderAuthInjectionStrategyFactory; }),
209
+ "./security/auth/default-authorizer-factory.js": () => Promise.resolve().then(function () { return defaultAuthorizerFactory; }),
210
+ "./security/auth/jwks-jwt-token-verifier-factory.js": () => Promise.resolve().then(function () { return jwksJwtTokenVerifierFactory; }),
211
+ "./security/auth/jwt-token-issuer-factory.js": () => Promise.resolve().then(function () { return jwtTokenIssuerFactory; }),
212
+ "./security/auth/jwt-token-verifier-factory.js": () => Promise.resolve().then(function () { return jwtTokenVerifierFactory; }),
213
+ "./security/auth/no-auth-injection-strategy-factory.js": () => Promise.resolve().then(function () { return noAuthInjectionStrategyFactory; }),
214
+ "./security/auth/none-token-provider-factory.js": () => Promise.resolve().then(function () { return noneTokenProviderFactory; }),
215
+ "./security/auth/noop-authorizer-factory.js": () => Promise.resolve().then(function () { return noopAuthorizerFactory; }),
216
+ "./security/auth/noop-token-issuer-factory.js": () => Promise.resolve().then(function () { return noopTokenIssuerFactory; }),
217
+ "./security/auth/noop-token-verifier-factory.js": () => Promise.resolve().then(function () { return noopTokenVerifierFactory; }),
218
+ "./security/auth/oauth2-authorizer-factory.js": () => Promise.resolve().then(function () { return oauth2AuthorizerFactory; }),
219
+ "./security/auth/oauth2-client-credentials-token-provider-factory.js": () => Promise.resolve().then(function () { return oauth2ClientCredentialsTokenProviderFactory; }),
220
+ "./security/auth/oauth2-pkce-token-provider-factory.js": () => Promise.resolve().then(function () { return oauth2PkceTokenProviderFactory; }),
221
+ "./security/auth/query-param-auth-injection-strategy-factory.js": () => Promise.resolve().then(function () { return queryParamAuthInjectionStrategyFactory; }),
222
+ "./security/auth/shared-secret-authorizer-factory.js": () => Promise.resolve().then(function () { return sharedSecretAuthorizerFactory; }),
223
+ "./security/auth/shared-secret-token-provider-factory.js": () => Promise.resolve().then(function () { return sharedSecretTokenProviderFactory; }),
224
+ "./security/auth/shared-secret-token-verifier-factory.js": () => Promise.resolve().then(function () { return sharedSecretTokenVerifierFactory; }),
225
+ "./security/auth/static-token-provider-factory.js": () => Promise.resolve().then(function () { return staticTokenProviderFactory; }),
226
+ "./security/auth/websocket-subprotocol-auth-injection-strategy-factory.js": () => Promise.resolve().then(function () { return websocketSubprotocolAuthInjectionStrategyFactory; }),
227
+ "./security/credential/dev-fixed-key-credential-provider-factory.js": () => Promise.resolve().then(function () { return devFixedKeyCredentialProviderFactory; }),
228
+ "./security/credential/env-credential-provider-factory.js": () => Promise.resolve().then(function () { return envCredentialProviderFactory; }),
229
+ "./security/credential/none-credential-provider-factory.js": () => Promise.resolve().then(function () { return noneCredentialProviderFactory; }),
230
+ "./security/credential/prompt-credential-provider-factory.js": () => Promise.resolve().then(function () { return promptCredentialProviderFactory; }),
231
+ "./security/credential/secret-store-credential-provider-factory.js": () => Promise.resolve().then(function () { return secretStoreCredentialProviderFactory; }),
232
+ "./security/credential/session-key-credential-provider-factory.js": () => Promise.resolve().then(function () { return sessionKeyCredentialProviderFactory; }),
233
+ "./security/credential/static-credential-provider-factory.js": () => Promise.resolve().then(function () { return staticCredentialProviderFactory; }),
234
+ "./security/default-security-manager-factory.js": () => Promise.resolve().then(function () { return defaultSecurityManagerFactory; }),
235
+ "./security/encryption/noop-encryption-manager-factory.js": () => Promise.resolve().then(function () { return noopEncryptionManagerFactory; }),
236
+ "./security/encryption/noop-secure-channel-manager-factory.js": () => Promise.resolve().then(function () { return noopSecureChannelManagerFactory; }),
237
+ "./security/keys/default-key-manager-factory.js": () => Promise.resolve().then(function () { return defaultKeyManagerFactory; }),
238
+ "./security/keys/in-memory-key-store-factory.js": () => Promise.resolve().then(function () { return inMemoryKeyStoreFactory; }),
239
+ "./security/keys/noop-key-validator-factory.js": () => Promise.resolve().then(function () { return noopKeyValidatorFactory; }),
240
+ "./security/node-security-profile-factory.js": () => Promise.resolve().then(function () { return nodeSecurityProfileFactory; }),
241
+ "./security/policy/default-security-policy-factory.js": () => Promise.resolve().then(function () { return defaultSecurityPolicyFactory; }),
242
+ "./security/policy/no-security-policy-factory.js": () => Promise.resolve().then(function () { return noSecurityPolicyFactory; }),
243
+ "./security/signing/eddsa-envelope-signer-factory.js": () => Promise.resolve().then(function () { return eddsaEnvelopeSignerFactory; }),
244
+ "./security/signing/eddsa-envelope-verifier-factory.js": () => Promise.resolve().then(function () { return eddsaEnvelopeVerifierFactory; }),
245
+ "./security/trust-store/noop-trust-store-provider-factory.js": () => Promise.resolve().then(function () { return noopTrustStoreProviderFactory; }),
246
+ "./sentinel/capability-aware-routing-policy-factory.js": () => Promise.resolve().then(function () { return capabilityAwareRoutingPolicyFactory; }),
247
+ "./sentinel/composite-routing-policy-factory.js": () => Promise.resolve().then(function () { return compositeRoutingPolicyFactory; }),
248
+ "./sentinel/hybrid-path-routing-policy-factory.js": () => Promise.resolve().then(function () { return hybridPathRoutingPolicyFactory; }),
249
+ "./sentinel/load-balancing/composite-load-balancing-strategy-factory.js": () => Promise.resolve().then(function () { return compositeLoadBalancingStrategyFactory; }),
250
+ "./sentinel/load-balancing/hrw-load-balancing-strategy-factory.js": () => Promise.resolve().then(function () { return hrwLoadBalancingStrategyFactory; }),
251
+ "./sentinel/load-balancing/load-balancing-profile-factory.js": () => Promise.resolve().then(function () { return loadBalancingProfileFactory; }),
252
+ "./sentinel/load-balancing/random-load-balancing-strategy-factory.js": () => Promise.resolve().then(function () { return randomLoadBalancingStrategyFactory; }),
253
+ "./sentinel/load-balancing/round-robin-load-balancing-strategy-factory.js": () => Promise.resolve().then(function () { return roundRobinLoadBalancingStrategyFactory; }),
254
+ "./sentinel/load-balancing/sticky-load-balancing-strategy-factory.js": () => Promise.resolve().then(function () { return stickyLoadBalancingStrategyFactory; }),
255
+ "./sentinel/routing-profile-factory.js": () => Promise.resolve().then(function () { return routingProfileFactory; }),
256
+ "./sentinel/sentinel-factory.js": () => Promise.resolve().then(function () { return sentinelFactory; }),
257
+ "./sentinel/store/route-store-factory.js": () => Promise.resolve().then(function () { return routeStoreFactory; }),
258
+ "./stickiness/simple-load-balancer-stickiness-manager-factory.js": () => Promise.resolve().then(function () { return simpleLoadBalancerStickinessManagerFactory; }),
259
+ "./telemetry/noop-trace-emitter-factory.js": () => Promise.resolve().then(function () { return noopTraceEmitterFactory; }),
260
+ "./telemetry/open-telemetry-trace-emitter-factory.js": () => Promise.resolve().then(function () { return openTelemetryTraceEmitterFactory; }),
261
+ "./telemetry/trace-emitter-profile-factory.js": () => Promise.resolve().then(function () { return traceEmitterProfileFactory; }),
262
+ "./welcome/default-welcome-service-factory.js": () => Promise.resolve().then(function () { return defaultWelcomeServiceFactory; }),
263
+ };
264
+
265
+ const FACTORY_MODULE_PREFIX$1 = '@naylence/runtime/naylence/fame/';
266
+ const BROWSER_DIST_SEGMENT = '/dist/browser/';
267
+ const NODE_ONLY_FACTORY_MODULES = new Set([
268
+ './connector/http-listener-factory.js',
269
+ './connector/websocket-listener-factory.js',
270
+ './telemetry/open-telemetry-trace-emitter-factory.js',
271
+ './security/credential/prompt-credential-provider-factory.js',
272
+ ]);
273
+ const BROWSER_ONLY_FACTORY_MODULES = new Set([
274
+ './security/auth/oauth2-pkce-token-provider-factory.js',
275
+ ]);
276
+ const isNodeEnvironment = typeof process !== 'undefined' && Boolean(process?.versions?.node);
277
+ function detectModuleUrl() {
278
+ // Prefer Node-friendly __filename when available.
279
+ if (typeof __filename === 'string') {
280
+ try {
281
+ const normalized = __filename.startsWith('file://')
282
+ ? __filename
283
+ : `file://${__filename}`;
284
+ return normalized;
285
+ }
286
+ catch {
287
+ // fall through to stack parsing
288
+ }
289
+ }
290
+ // Fallback to parsing the current stack trace to discover the executing module URL.
291
+ try {
292
+ throw new Error();
293
+ }
294
+ catch (error) {
295
+ const stack = typeof error === 'object' && error && 'stack' in error
296
+ ? String(error.stack ?? '')
297
+ : '';
298
+ const lines = stack.split('\n');
299
+ for (const line of lines) {
300
+ const match = line.match(/(https?:\/\/[^\s)]+|file:\/\/[^\s)]+|\/[^\s)]+\.(?:js|ts))/u);
301
+ if (!match) {
302
+ continue;
303
+ }
304
+ const candidate = match[1];
305
+ if (candidate.startsWith('http://') || candidate.startsWith('https://')) {
306
+ return candidate;
307
+ }
308
+ if (candidate.startsWith('file://')) {
309
+ return candidate;
310
+ }
311
+ return `file://${candidate}`;
312
+ }
313
+ }
314
+ return null;
315
+ }
316
+ function computeBrowserFactoryBase(rawUrl) {
317
+ if (!rawUrl) {
318
+ return null;
319
+ }
320
+ const sanitized = rawUrl.split('?')[0]?.split('#')[0] ?? rawUrl;
321
+ const esmMarker = '/dist/esm/naylence/fame/';
322
+ const browserMarker = '/dist/browser/';
323
+ const distMarker = '/dist/';
324
+ if (sanitized.includes(esmMarker)) {
325
+ return sanitized.slice(0, sanitized.indexOf(esmMarker) + esmMarker.length);
326
+ }
327
+ if (rawUrl.includes(BROWSER_DIST_SEGMENT)) {
328
+ return new URL('../esm/naylence/fame/', rawUrl).href;
329
+ }
330
+ if (rawUrl.startsWith('http://') || rawUrl.startsWith('https://')) {
331
+ try {
332
+ const parsed = new URL(rawUrl);
333
+ const viteDepsSegment = '/node_modules/.vite/deps/';
334
+ if (parsed.pathname.includes(viteDepsSegment)) {
335
+ const baseOrigin = `${parsed.protocol}//${parsed.host}`;
336
+ return `${baseOrigin}/node_modules/@naylence/runtime/dist/esm/naylence/fame/`;
337
+ }
338
+ }
339
+ catch {
340
+ // ignore and fall through to null
341
+ }
342
+ }
343
+ if (sanitized.includes(browserMarker)) {
344
+ const base = sanitized.slice(0, sanitized.indexOf(browserMarker) + browserMarker.length);
345
+ return `${base.replace(/browser\/?$/u, '')}esm/naylence/fame/`;
346
+ }
347
+ if (sanitized.includes(distMarker)) {
348
+ const index = sanitized.indexOf(distMarker);
349
+ const base = sanitized.slice(0, index + distMarker.length);
350
+ return `${base}esm/naylence/fame/`;
351
+ }
352
+ // Fallback for development: if this is a source file path, compute dist/esm path
353
+ const srcMarker = '/src/naylence/fame/';
354
+ if (sanitized.includes(srcMarker)) {
355
+ const index = sanitized.indexOf(srcMarker);
356
+ const projectRoot = sanitized.slice(0, index);
357
+ return `${projectRoot}/dist/esm/naylence/fame/`;
358
+ }
359
+ return null;
360
+ }
361
+ const moduleUrl = detectModuleUrl();
362
+ const browserFactoryBase = computeBrowserFactoryBase(moduleUrl);
363
+ function resolveFactoryModuleSpecifier$1(specifier) {
364
+ if (specifier.startsWith('../')) {
365
+ const relativePath = specifier.slice('../'.length);
366
+ return `${FACTORY_MODULE_PREFIX$1}${relativePath}`;
367
+ }
368
+ if (specifier.startsWith('./')) {
369
+ const relativePath = specifier.slice('./'.length);
370
+ return `${FACTORY_MODULE_PREFIX$1}${relativePath}`;
371
+ }
372
+ return null;
373
+ }
374
+ function resolveModuleCandidates(spec) {
375
+ const packageSpecifier = resolveFactoryModuleSpecifier$1(spec);
376
+ const candidates = [];
377
+ const preferSource = typeof moduleUrl === 'string' && moduleUrl.includes('/src/');
378
+ const addCandidate = (candidate) => {
379
+ if (!candidate) {
380
+ return;
381
+ }
382
+ if (!candidates.includes(candidate)) {
383
+ candidates.push(candidate);
384
+ }
385
+ };
386
+ if (preferSource && spec.startsWith('./')) {
387
+ const baseSource = `../${spec.slice(2)}`;
388
+ addCandidate(baseSource);
389
+ if (baseSource.endsWith('.js')) {
390
+ addCandidate(baseSource.replace(/\.js$/u, '.ts'));
391
+ }
392
+ }
393
+ if (browserFactoryBase && spec.startsWith('./')) {
394
+ const browserCandidate = new URL(spec.slice('./'.length), browserFactoryBase).href;
395
+ addCandidate(browserCandidate);
396
+ if (browserCandidate.endsWith('.js')) {
397
+ addCandidate(browserCandidate.replace(/\.js$/u, '.ts'));
398
+ }
399
+ }
400
+ if (packageSpecifier) {
401
+ addCandidate(packageSpecifier);
402
+ if (packageSpecifier.endsWith('.js')) {
403
+ addCandidate(packageSpecifier.replace(/\.js$/u, '.ts'));
404
+ }
405
+ }
406
+ const baseFallback = spec.startsWith('./') ? `../${spec.slice(2)}` : spec;
407
+ addCandidate(baseFallback);
408
+ if (baseFallback.endsWith('.js')) {
409
+ addCandidate(baseFallback.replace(/\.js$/u, '.ts'));
410
+ }
411
+ return candidates;
412
+ }
413
+ async function performRegistration(registry) {
414
+ await Promise.all(MODULES.map(async (spec) => {
415
+ if (!isNodeEnvironment && NODE_ONLY_FACTORY_MODULES.has(spec)) {
416
+ return;
417
+ }
418
+ if (isNodeEnvironment && BROWSER_ONLY_FACTORY_MODULES.has(spec)) {
419
+ return;
420
+ }
421
+ try {
422
+ let mod;
423
+ let lastError;
424
+ const staticLoader = MODULE_LOADERS?.[spec];
425
+ if (staticLoader) {
426
+ try {
427
+ mod = await staticLoader();
428
+ }
429
+ catch (error) {
430
+ lastError = error;
431
+ }
432
+ }
433
+ if (!mod) {
434
+ const candidates = resolveModuleCandidates(spec);
435
+ for (const [index, candidate] of candidates.entries()) {
436
+ try {
437
+ mod = await import(/* @vite-ignore */ candidate);
438
+ lastError = undefined;
439
+ break;
440
+ }
441
+ catch (error) {
442
+ lastError = error;
443
+ const isLastCandidate = index === candidates.length - 1;
444
+ if (isLastCandidate) {
445
+ throw error;
446
+ }
447
+ const message = error instanceof Error ? error.message : String(error);
448
+ const moduleNotFound = message.includes('Cannot find module') ||
449
+ message.includes('ERR_MODULE_NOT_FOUND') ||
450
+ message.includes('Unknown file extension') ||
451
+ message.includes('Failed to fetch dynamically imported module') ||
452
+ message.includes('Importing a module script failed');
453
+ if (!moduleNotFound) {
454
+ throw error;
455
+ }
456
+ }
457
+ }
458
+ }
459
+ if (!mod) {
460
+ throw (lastError ?? new Error(`Unable to import factory module: ${spec}`));
461
+ }
462
+ const meta = mod.FACTORY_META;
463
+ const Ctor = mod.default;
464
+ if (!meta?.base || !meta?.key || typeof Ctor !== 'function') {
465
+ console.warn('[factory-manifest] skipped', spec, '— missing FACTORY_META or default export ctor');
466
+ return;
467
+ }
468
+ registry.registerFactory(meta.base, meta.key, Ctor);
469
+ }
470
+ catch (error) {
471
+ const reason = error instanceof Error ? error.message : String(error);
472
+ console.warn('[factory-manifest] skipped', spec, '-', reason);
473
+ }
474
+ }));
475
+ }
476
+ async function registerDefaultFactories(registry = factory.Registry) {
477
+ await performRegistration(registry);
478
+ }
479
+ /**
480
+ * Register all default Naylence runtime factories into the supplied registry.
481
+ *
482
+ * @param registry Registry implementation to receive the default runtime factories.
483
+ */
484
+ async function registerRuntimeFactories(registry = factory.Registry) {
485
+ if (registry === factory.Registry) {
486
+ await ensureDefaultRegistration();
487
+ return;
488
+ }
489
+ await performRegistration(registry);
490
+ }
491
+ let defaultRegistrationPromise = null;
492
+ let defaultRegistrationError = null;
493
+ async function ensureDefaultRegistration() {
494
+ if (defaultRegistrationError) {
495
+ throw defaultRegistrationError;
496
+ }
497
+ if (!defaultRegistrationPromise) {
498
+ defaultRegistrationError = null;
499
+ defaultRegistrationPromise = performRegistration(factory.Registry).catch((error) => {
500
+ defaultRegistrationError = error;
501
+ defaultRegistrationPromise = null;
502
+ throw error;
503
+ });
504
+ }
505
+ await defaultRegistrationPromise;
506
+ }
507
+ async function ensureRuntimeFactoriesRegistered(registry = factory.Registry) {
508
+ if (registry !== factory.Registry) {
509
+ await performRegistration(registry);
510
+ return;
511
+ }
512
+ await ensureDefaultRegistration();
513
+ }
514
+
102
515
  // This file is auto-generated during build - do not edit manually
103
- // Generated from package.json version: 0.3.14
516
+ // Generated from package.json version: 0.3.15
104
517
  /**
105
518
  * The package version, injected at build time.
106
519
  * @internal
107
520
  */
108
- const VERSION = '0.3.14';
521
+ const VERSION = '0.3.15';
522
+
523
+ let initialized = false;
524
+ const runtimePlugin = {
525
+ name: 'naylence:runtime',
526
+ version: VERSION,
527
+ async register() {
528
+ // console.log('[naylence:runtime] register() called, initialized=', initialized);
529
+ if (initialized) {
530
+ // console.log('[naylence:runtime] already initialized, skipping');
531
+ return;
532
+ }
533
+ initialized = true;
534
+ // console.log('[naylence:runtime] registering runtime factories...');
535
+ // Register factories from manifest
536
+ await registerRuntimeFactories();
537
+ // Import modules with side-effect registrations (not in manifest)
538
+ await Promise.resolve().then(function () { return websocketTransportProvisioner; });
539
+ // console.log('[naylence:runtime] runtime factories registered');
540
+ },
541
+ };
542
+ const RUNTIME_PLUGIN_SPECIFIER = runtimePlugin.name;
543
+
544
+ var plugin = /*#__PURE__*/Object.freeze({
545
+ __proto__: null,
546
+ RUNTIME_PLUGIN_SPECIFIER: RUNTIME_PLUGIN_SPECIFIER,
547
+ default: runtimePlugin
548
+ });
109
549
 
110
550
  /**
111
551
  * Fame protocol specific error classes with WebSocket close codes and proper inheritance.
@@ -14196,419 +14636,6 @@ var extendedFameConfig = /*#__PURE__*/Object.freeze({
14196
14636
  normalizeExtendedFameConfig: normalizeExtendedFameConfig
14197
14637
  });
14198
14638
 
14199
- /**
14200
- * AUTO-GENERATED FILE. DO NOT EDIT DIRECTLY.
14201
- * Generated by scripts/generate-factory-manifest.mjs
14202
- *
14203
- * Provides the list of runtime factory modules for registration.
14204
- */
14205
- const MODULES = [
14206
- "./connector/broadcast-channel-connector-factory.js",
14207
- "./connector/broadcast-channel-listener-factory.js",
14208
- "./connector/http-listener-factory.js",
14209
- "./connector/http-stateless-connector-factory.js",
14210
- "./connector/inpage-connector-factory.js",
14211
- "./connector/inpage-listener-factory.js",
14212
- "./connector/websocket-connector-factory.js",
14213
- "./connector/websocket-listener-factory.js",
14214
- "./delivery/at-least-once-delivery-policy-factory.js",
14215
- "./delivery/at-most-once-delivery-policy-factory.js",
14216
- "./delivery/delivery-profile-factory.js",
14217
- "./fabric/in-process-fame-fabric-factory.js",
14218
- "./node/admission/admission-profile-factory.js",
14219
- "./node/admission/direct-admission-client-factory.js",
14220
- "./node/admission/noop-admission-client-factory.js",
14221
- "./node/admission/welcome-service-client-factory.js",
14222
- "./node/default-node-identity-policy-factory.js",
14223
- "./node/node-factory.js",
14224
- "./node/node-identity-policy-profile-factory.js",
14225
- "./node/token-subject-node-identity-policy-factory.js",
14226
- "./placement/static-node-placement-strategy-factory.js",
14227
- "./security/auth/bearer-token-header-auth-injection-strategy-factory.js",
14228
- "./security/auth/default-authorizer-factory.js",
14229
- "./security/auth/jwks-jwt-token-verifier-factory.js",
14230
- "./security/auth/jwt-token-issuer-factory.js",
14231
- "./security/auth/jwt-token-verifier-factory.js",
14232
- "./security/auth/no-auth-injection-strategy-factory.js",
14233
- "./security/auth/none-token-provider-factory.js",
14234
- "./security/auth/noop-authorizer-factory.js",
14235
- "./security/auth/noop-token-issuer-factory.js",
14236
- "./security/auth/noop-token-verifier-factory.js",
14237
- "./security/auth/oauth2-authorizer-factory.js",
14238
- "./security/auth/oauth2-client-credentials-token-provider-factory.js",
14239
- "./security/auth/oauth2-pkce-token-provider-factory.js",
14240
- "./security/auth/query-param-auth-injection-strategy-factory.js",
14241
- "./security/auth/shared-secret-authorizer-factory.js",
14242
- "./security/auth/shared-secret-token-provider-factory.js",
14243
- "./security/auth/shared-secret-token-verifier-factory.js",
14244
- "./security/auth/static-token-provider-factory.js",
14245
- "./security/auth/websocket-subprotocol-auth-injection-strategy-factory.js",
14246
- "./security/credential/dev-fixed-key-credential-provider-factory.js",
14247
- "./security/credential/env-credential-provider-factory.js",
14248
- "./security/credential/none-credential-provider-factory.js",
14249
- "./security/credential/prompt-credential-provider-factory.js",
14250
- "./security/credential/secret-store-credential-provider-factory.js",
14251
- "./security/credential/session-key-credential-provider-factory.js",
14252
- "./security/credential/static-credential-provider-factory.js",
14253
- "./security/default-security-manager-factory.js",
14254
- "./security/encryption/noop-encryption-manager-factory.js",
14255
- "./security/encryption/noop-secure-channel-manager-factory.js",
14256
- "./security/keys/default-key-manager-factory.js",
14257
- "./security/keys/in-memory-key-store-factory.js",
14258
- "./security/keys/noop-key-validator-factory.js",
14259
- "./security/node-security-profile-factory.js",
14260
- "./security/policy/default-security-policy-factory.js",
14261
- "./security/policy/no-security-policy-factory.js",
14262
- "./security/signing/eddsa-envelope-signer-factory.js",
14263
- "./security/signing/eddsa-envelope-verifier-factory.js",
14264
- "./security/trust-store/noop-trust-store-provider-factory.js",
14265
- "./sentinel/capability-aware-routing-policy-factory.js",
14266
- "./sentinel/composite-routing-policy-factory.js",
14267
- "./sentinel/hybrid-path-routing-policy-factory.js",
14268
- "./sentinel/load-balancing/composite-load-balancing-strategy-factory.js",
14269
- "./sentinel/load-balancing/hrw-load-balancing-strategy-factory.js",
14270
- "./sentinel/load-balancing/load-balancing-profile-factory.js",
14271
- "./sentinel/load-balancing/random-load-balancing-strategy-factory.js",
14272
- "./sentinel/load-balancing/round-robin-load-balancing-strategy-factory.js",
14273
- "./sentinel/load-balancing/sticky-load-balancing-strategy-factory.js",
14274
- "./sentinel/routing-profile-factory.js",
14275
- "./sentinel/sentinel-factory.js",
14276
- "./sentinel/store/route-store-factory.js",
14277
- "./stickiness/simple-load-balancer-stickiness-manager-factory.js",
14278
- "./telemetry/noop-trace-emitter-factory.js",
14279
- "./telemetry/open-telemetry-trace-emitter-factory.js",
14280
- "./telemetry/trace-emitter-profile-factory.js",
14281
- "./welcome/default-welcome-service-factory.js"
14282
- ];
14283
- const MODULE_LOADERS = {
14284
- "./connector/broadcast-channel-connector-factory.js": () => Promise.resolve().then(function () { return broadcastChannelConnectorFactory; }),
14285
- "./connector/broadcast-channel-listener-factory.js": () => Promise.resolve().then(function () { return broadcastChannelListenerFactory; }),
14286
- "./connector/http-listener-factory.js": () => Promise.resolve().then(function () { return httpListenerFactory; }),
14287
- "./connector/http-stateless-connector-factory.js": () => Promise.resolve().then(function () { return httpStatelessConnectorFactory; }),
14288
- "./connector/inpage-connector-factory.js": () => Promise.resolve().then(function () { return inpageConnectorFactory; }),
14289
- "./connector/inpage-listener-factory.js": () => Promise.resolve().then(function () { return inpageListenerFactory; }),
14290
- "./connector/websocket-connector-factory.js": () => Promise.resolve().then(function () { return websocketConnectorFactory; }),
14291
- "./connector/websocket-listener-factory.js": () => Promise.resolve().then(function () { return websocketListenerFactory; }),
14292
- "./delivery/at-least-once-delivery-policy-factory.js": () => Promise.resolve().then(function () { return atLeastOnceDeliveryPolicyFactory; }),
14293
- "./delivery/at-most-once-delivery-policy-factory.js": () => Promise.resolve().then(function () { return atMostOnceDeliveryPolicyFactory; }),
14294
- "./delivery/delivery-profile-factory.js": () => Promise.resolve().then(function () { return deliveryProfileFactory; }),
14295
- "./fabric/in-process-fame-fabric-factory.js": () => Promise.resolve().then(function () { return inProcessFameFabricFactory; }),
14296
- "./node/admission/admission-profile-factory.js": () => Promise.resolve().then(function () { return admissionProfileFactory; }),
14297
- "./node/admission/direct-admission-client-factory.js": () => Promise.resolve().then(function () { return directAdmissionClientFactory; }),
14298
- "./node/admission/noop-admission-client-factory.js": () => Promise.resolve().then(function () { return noopAdmissionClientFactory; }),
14299
- "./node/admission/welcome-service-client-factory.js": () => Promise.resolve().then(function () { return welcomeServiceClientFactory; }),
14300
- "./node/default-node-identity-policy-factory.js": () => Promise.resolve().then(function () { return defaultNodeIdentityPolicyFactory; }),
14301
- "./node/node-factory.js": () => Promise.resolve().then(function () { return nodeFactory; }),
14302
- "./node/node-identity-policy-profile-factory.js": () => Promise.resolve().then(function () { return nodeIdentityPolicyProfileFactory; }),
14303
- "./node/token-subject-node-identity-policy-factory.js": () => Promise.resolve().then(function () { return tokenSubjectNodeIdentityPolicyFactory; }),
14304
- "./placement/static-node-placement-strategy-factory.js": () => Promise.resolve().then(function () { return staticNodePlacementStrategyFactory; }),
14305
- "./security/auth/bearer-token-header-auth-injection-strategy-factory.js": () => Promise.resolve().then(function () { return bearerTokenHeaderAuthInjectionStrategyFactory; }),
14306
- "./security/auth/default-authorizer-factory.js": () => Promise.resolve().then(function () { return defaultAuthorizerFactory; }),
14307
- "./security/auth/jwks-jwt-token-verifier-factory.js": () => Promise.resolve().then(function () { return jwksJwtTokenVerifierFactory; }),
14308
- "./security/auth/jwt-token-issuer-factory.js": () => Promise.resolve().then(function () { return jwtTokenIssuerFactory; }),
14309
- "./security/auth/jwt-token-verifier-factory.js": () => Promise.resolve().then(function () { return jwtTokenVerifierFactory; }),
14310
- "./security/auth/no-auth-injection-strategy-factory.js": () => Promise.resolve().then(function () { return noAuthInjectionStrategyFactory; }),
14311
- "./security/auth/none-token-provider-factory.js": () => Promise.resolve().then(function () { return noneTokenProviderFactory; }),
14312
- "./security/auth/noop-authorizer-factory.js": () => Promise.resolve().then(function () { return noopAuthorizerFactory; }),
14313
- "./security/auth/noop-token-issuer-factory.js": () => Promise.resolve().then(function () { return noopTokenIssuerFactory; }),
14314
- "./security/auth/noop-token-verifier-factory.js": () => Promise.resolve().then(function () { return noopTokenVerifierFactory; }),
14315
- "./security/auth/oauth2-authorizer-factory.js": () => Promise.resolve().then(function () { return oauth2AuthorizerFactory; }),
14316
- "./security/auth/oauth2-client-credentials-token-provider-factory.js": () => Promise.resolve().then(function () { return oauth2ClientCredentialsTokenProviderFactory; }),
14317
- "./security/auth/oauth2-pkce-token-provider-factory.js": () => Promise.resolve().then(function () { return oauth2PkceTokenProviderFactory; }),
14318
- "./security/auth/query-param-auth-injection-strategy-factory.js": () => Promise.resolve().then(function () { return queryParamAuthInjectionStrategyFactory; }),
14319
- "./security/auth/shared-secret-authorizer-factory.js": () => Promise.resolve().then(function () { return sharedSecretAuthorizerFactory; }),
14320
- "./security/auth/shared-secret-token-provider-factory.js": () => Promise.resolve().then(function () { return sharedSecretTokenProviderFactory; }),
14321
- "./security/auth/shared-secret-token-verifier-factory.js": () => Promise.resolve().then(function () { return sharedSecretTokenVerifierFactory; }),
14322
- "./security/auth/static-token-provider-factory.js": () => Promise.resolve().then(function () { return staticTokenProviderFactory; }),
14323
- "./security/auth/websocket-subprotocol-auth-injection-strategy-factory.js": () => Promise.resolve().then(function () { return websocketSubprotocolAuthInjectionStrategyFactory; }),
14324
- "./security/credential/dev-fixed-key-credential-provider-factory.js": () => Promise.resolve().then(function () { return devFixedKeyCredentialProviderFactory; }),
14325
- "./security/credential/env-credential-provider-factory.js": () => Promise.resolve().then(function () { return envCredentialProviderFactory; }),
14326
- "./security/credential/none-credential-provider-factory.js": () => Promise.resolve().then(function () { return noneCredentialProviderFactory; }),
14327
- "./security/credential/prompt-credential-provider-factory.js": () => Promise.resolve().then(function () { return promptCredentialProviderFactory; }),
14328
- "./security/credential/secret-store-credential-provider-factory.js": () => Promise.resolve().then(function () { return secretStoreCredentialProviderFactory; }),
14329
- "./security/credential/session-key-credential-provider-factory.js": () => Promise.resolve().then(function () { return sessionKeyCredentialProviderFactory; }),
14330
- "./security/credential/static-credential-provider-factory.js": () => Promise.resolve().then(function () { return staticCredentialProviderFactory; }),
14331
- "./security/default-security-manager-factory.js": () => Promise.resolve().then(function () { return defaultSecurityManagerFactory; }),
14332
- "./security/encryption/noop-encryption-manager-factory.js": () => Promise.resolve().then(function () { return noopEncryptionManagerFactory; }),
14333
- "./security/encryption/noop-secure-channel-manager-factory.js": () => Promise.resolve().then(function () { return noopSecureChannelManagerFactory; }),
14334
- "./security/keys/default-key-manager-factory.js": () => Promise.resolve().then(function () { return defaultKeyManagerFactory; }),
14335
- "./security/keys/in-memory-key-store-factory.js": () => Promise.resolve().then(function () { return inMemoryKeyStoreFactory; }),
14336
- "./security/keys/noop-key-validator-factory.js": () => Promise.resolve().then(function () { return noopKeyValidatorFactory; }),
14337
- "./security/node-security-profile-factory.js": () => Promise.resolve().then(function () { return nodeSecurityProfileFactory; }),
14338
- "./security/policy/default-security-policy-factory.js": () => Promise.resolve().then(function () { return defaultSecurityPolicyFactory; }),
14339
- "./security/policy/no-security-policy-factory.js": () => Promise.resolve().then(function () { return noSecurityPolicyFactory; }),
14340
- "./security/signing/eddsa-envelope-signer-factory.js": () => Promise.resolve().then(function () { return eddsaEnvelopeSignerFactory; }),
14341
- "./security/signing/eddsa-envelope-verifier-factory.js": () => Promise.resolve().then(function () { return eddsaEnvelopeVerifierFactory; }),
14342
- "./security/trust-store/noop-trust-store-provider-factory.js": () => Promise.resolve().then(function () { return noopTrustStoreProviderFactory; }),
14343
- "./sentinel/capability-aware-routing-policy-factory.js": () => Promise.resolve().then(function () { return capabilityAwareRoutingPolicyFactory; }),
14344
- "./sentinel/composite-routing-policy-factory.js": () => Promise.resolve().then(function () { return compositeRoutingPolicyFactory; }),
14345
- "./sentinel/hybrid-path-routing-policy-factory.js": () => Promise.resolve().then(function () { return hybridPathRoutingPolicyFactory; }),
14346
- "./sentinel/load-balancing/composite-load-balancing-strategy-factory.js": () => Promise.resolve().then(function () { return compositeLoadBalancingStrategyFactory; }),
14347
- "./sentinel/load-balancing/hrw-load-balancing-strategy-factory.js": () => Promise.resolve().then(function () { return hrwLoadBalancingStrategyFactory; }),
14348
- "./sentinel/load-balancing/load-balancing-profile-factory.js": () => Promise.resolve().then(function () { return loadBalancingProfileFactory; }),
14349
- "./sentinel/load-balancing/random-load-balancing-strategy-factory.js": () => Promise.resolve().then(function () { return randomLoadBalancingStrategyFactory; }),
14350
- "./sentinel/load-balancing/round-robin-load-balancing-strategy-factory.js": () => Promise.resolve().then(function () { return roundRobinLoadBalancingStrategyFactory; }),
14351
- "./sentinel/load-balancing/sticky-load-balancing-strategy-factory.js": () => Promise.resolve().then(function () { return stickyLoadBalancingStrategyFactory; }),
14352
- "./sentinel/routing-profile-factory.js": () => Promise.resolve().then(function () { return routingProfileFactory; }),
14353
- "./sentinel/sentinel-factory.js": () => Promise.resolve().then(function () { return sentinelFactory; }),
14354
- "./sentinel/store/route-store-factory.js": () => Promise.resolve().then(function () { return routeStoreFactory; }),
14355
- "./stickiness/simple-load-balancer-stickiness-manager-factory.js": () => Promise.resolve().then(function () { return simpleLoadBalancerStickinessManagerFactory; }),
14356
- "./telemetry/noop-trace-emitter-factory.js": () => Promise.resolve().then(function () { return noopTraceEmitterFactory; }),
14357
- "./telemetry/open-telemetry-trace-emitter-factory.js": () => Promise.resolve().then(function () { return openTelemetryTraceEmitterFactory; }),
14358
- "./telemetry/trace-emitter-profile-factory.js": () => Promise.resolve().then(function () { return traceEmitterProfileFactory; }),
14359
- "./welcome/default-welcome-service-factory.js": () => Promise.resolve().then(function () { return defaultWelcomeServiceFactory; }),
14360
- };
14361
-
14362
- const FACTORY_MODULE_PREFIX$1 = '@naylence/runtime/naylence/fame/';
14363
- const BROWSER_DIST_SEGMENT = '/dist/browser/';
14364
- const NODE_ONLY_FACTORY_MODULES = new Set([
14365
- './connector/http-listener-factory.js',
14366
- './connector/websocket-listener-factory.js',
14367
- './telemetry/open-telemetry-trace-emitter-factory.js',
14368
- './security/credential/prompt-credential-provider-factory.js',
14369
- ]);
14370
- const BROWSER_ONLY_FACTORY_MODULES = new Set([
14371
- './security/auth/oauth2-pkce-token-provider-factory.js',
14372
- ]);
14373
- const isNodeEnvironment = typeof process !== 'undefined' && Boolean(process?.versions?.node);
14374
- function detectModuleUrl() {
14375
- // Prefer Node-friendly __filename when available.
14376
- if (typeof __filename === 'string') {
14377
- try {
14378
- const normalized = __filename.startsWith('file://')
14379
- ? __filename
14380
- : `file://${__filename}`;
14381
- return normalized;
14382
- }
14383
- catch {
14384
- // fall through to stack parsing
14385
- }
14386
- }
14387
- // Fallback to parsing the current stack trace to discover the executing module URL.
14388
- try {
14389
- throw new Error();
14390
- }
14391
- catch (error) {
14392
- const stack = typeof error === 'object' && error && 'stack' in error
14393
- ? String(error.stack ?? '')
14394
- : '';
14395
- const lines = stack.split('\n');
14396
- for (const line of lines) {
14397
- const match = line.match(/(https?:\/\/[^\s)]+|file:\/\/[^\s)]+|\/[^\s)]+\.(?:js|ts))/u);
14398
- if (!match) {
14399
- continue;
14400
- }
14401
- const candidate = match[1];
14402
- if (candidate.startsWith('http://') || candidate.startsWith('https://')) {
14403
- return candidate;
14404
- }
14405
- if (candidate.startsWith('file://')) {
14406
- return candidate;
14407
- }
14408
- return `file://${candidate}`;
14409
- }
14410
- }
14411
- return null;
14412
- }
14413
- function computeBrowserFactoryBase(rawUrl) {
14414
- if (!rawUrl) {
14415
- return null;
14416
- }
14417
- const sanitized = rawUrl.split('?')[0]?.split('#')[0] ?? rawUrl;
14418
- const esmMarker = '/dist/esm/naylence/fame/';
14419
- const browserMarker = '/dist/browser/';
14420
- const distMarker = '/dist/';
14421
- if (sanitized.includes(esmMarker)) {
14422
- return sanitized.slice(0, sanitized.indexOf(esmMarker) + esmMarker.length);
14423
- }
14424
- if (rawUrl.includes(BROWSER_DIST_SEGMENT)) {
14425
- return new URL('../esm/naylence/fame/', rawUrl).href;
14426
- }
14427
- if (rawUrl.startsWith('http://') || rawUrl.startsWith('https://')) {
14428
- try {
14429
- const parsed = new URL(rawUrl);
14430
- const viteDepsSegment = '/node_modules/.vite/deps/';
14431
- if (parsed.pathname.includes(viteDepsSegment)) {
14432
- const baseOrigin = `${parsed.protocol}//${parsed.host}`;
14433
- return `${baseOrigin}/node_modules/@naylence/runtime/dist/esm/naylence/fame/`;
14434
- }
14435
- }
14436
- catch {
14437
- // ignore and fall through to null
14438
- }
14439
- }
14440
- if (sanitized.includes(browserMarker)) {
14441
- const base = sanitized.slice(0, sanitized.indexOf(browserMarker) + browserMarker.length);
14442
- return `${base.replace(/browser\/?$/u, '')}esm/naylence/fame/`;
14443
- }
14444
- if (sanitized.includes(distMarker)) {
14445
- const index = sanitized.indexOf(distMarker);
14446
- const base = sanitized.slice(0, index + distMarker.length);
14447
- return `${base}esm/naylence/fame/`;
14448
- }
14449
- // Fallback for development: if this is a source file path, compute dist/esm path
14450
- const srcMarker = '/src/naylence/fame/';
14451
- if (sanitized.includes(srcMarker)) {
14452
- const index = sanitized.indexOf(srcMarker);
14453
- const projectRoot = sanitized.slice(0, index);
14454
- return `${projectRoot}/dist/esm/naylence/fame/`;
14455
- }
14456
- return null;
14457
- }
14458
- const moduleUrl = detectModuleUrl();
14459
- const browserFactoryBase = computeBrowserFactoryBase(moduleUrl);
14460
- function resolveFactoryModuleSpecifier$1(specifier) {
14461
- if (specifier.startsWith('../')) {
14462
- const relativePath = specifier.slice('../'.length);
14463
- return `${FACTORY_MODULE_PREFIX$1}${relativePath}`;
14464
- }
14465
- if (specifier.startsWith('./')) {
14466
- const relativePath = specifier.slice('./'.length);
14467
- return `${FACTORY_MODULE_PREFIX$1}${relativePath}`;
14468
- }
14469
- return null;
14470
- }
14471
- function resolveModuleCandidates(spec) {
14472
- const packageSpecifier = resolveFactoryModuleSpecifier$1(spec);
14473
- const candidates = [];
14474
- const preferSource = typeof moduleUrl === 'string' && moduleUrl.includes('/src/');
14475
- const addCandidate = (candidate) => {
14476
- if (!candidate) {
14477
- return;
14478
- }
14479
- if (!candidates.includes(candidate)) {
14480
- candidates.push(candidate);
14481
- }
14482
- };
14483
- if (preferSource && spec.startsWith('./')) {
14484
- const baseSource = `../${spec.slice(2)}`;
14485
- addCandidate(baseSource);
14486
- if (baseSource.endsWith('.js')) {
14487
- addCandidate(baseSource.replace(/\.js$/u, '.ts'));
14488
- }
14489
- }
14490
- if (browserFactoryBase && spec.startsWith('./')) {
14491
- const browserCandidate = new URL(spec.slice('./'.length), browserFactoryBase).href;
14492
- addCandidate(browserCandidate);
14493
- if (browserCandidate.endsWith('.js')) {
14494
- addCandidate(browserCandidate.replace(/\.js$/u, '.ts'));
14495
- }
14496
- }
14497
- if (packageSpecifier) {
14498
- addCandidate(packageSpecifier);
14499
- if (packageSpecifier.endsWith('.js')) {
14500
- addCandidate(packageSpecifier.replace(/\.js$/u, '.ts'));
14501
- }
14502
- }
14503
- const baseFallback = spec.startsWith('./') ? `../${spec.slice(2)}` : spec;
14504
- addCandidate(baseFallback);
14505
- if (baseFallback.endsWith('.js')) {
14506
- addCandidate(baseFallback.replace(/\.js$/u, '.ts'));
14507
- }
14508
- return candidates;
14509
- }
14510
- async function performRegistration(registry) {
14511
- await Promise.all(MODULES.map(async (spec) => {
14512
- if (!isNodeEnvironment && NODE_ONLY_FACTORY_MODULES.has(spec)) {
14513
- return;
14514
- }
14515
- if (isNodeEnvironment && BROWSER_ONLY_FACTORY_MODULES.has(spec)) {
14516
- return;
14517
- }
14518
- try {
14519
- let mod;
14520
- let lastError;
14521
- const staticLoader = MODULE_LOADERS?.[spec];
14522
- if (staticLoader) {
14523
- try {
14524
- mod = await staticLoader();
14525
- }
14526
- catch (error) {
14527
- lastError = error;
14528
- }
14529
- }
14530
- if (!mod) {
14531
- const candidates = resolveModuleCandidates(spec);
14532
- for (const [index, candidate] of candidates.entries()) {
14533
- try {
14534
- mod = await import(/* @vite-ignore */ candidate);
14535
- lastError = undefined;
14536
- break;
14537
- }
14538
- catch (error) {
14539
- lastError = error;
14540
- const isLastCandidate = index === candidates.length - 1;
14541
- if (isLastCandidate) {
14542
- throw error;
14543
- }
14544
- const message = error instanceof Error ? error.message : String(error);
14545
- const moduleNotFound = message.includes('Cannot find module') ||
14546
- message.includes('ERR_MODULE_NOT_FOUND') ||
14547
- message.includes('Unknown file extension') ||
14548
- message.includes('Failed to fetch dynamically imported module') ||
14549
- message.includes('Importing a module script failed');
14550
- if (!moduleNotFound) {
14551
- throw error;
14552
- }
14553
- }
14554
- }
14555
- }
14556
- if (!mod) {
14557
- throw (lastError ?? new Error(`Unable to import factory module: ${spec}`));
14558
- }
14559
- const meta = mod.FACTORY_META;
14560
- const Ctor = mod.default;
14561
- if (!meta?.base || !meta?.key || typeof Ctor !== 'function') {
14562
- console.warn('[factory-manifest] skipped', spec, '— missing FACTORY_META or default export ctor');
14563
- return;
14564
- }
14565
- registry.registerFactory(meta.base, meta.key, Ctor);
14566
- }
14567
- catch (error) {
14568
- const reason = error instanceof Error ? error.message : String(error);
14569
- console.warn('[factory-manifest] skipped', spec, '-', reason);
14570
- }
14571
- }));
14572
- }
14573
- async function registerDefaultFactories(registry = factory.Registry) {
14574
- await performRegistration(registry);
14575
- }
14576
- /**
14577
- * Register all default Naylence runtime factories into the supplied registry.
14578
- *
14579
- * @param registry Registry implementation to receive the default runtime factories.
14580
- */
14581
- async function registerRuntimeFactories(registry = factory.Registry) {
14582
- if (registry === factory.Registry) {
14583
- await ensureDefaultRegistration();
14584
- return;
14585
- }
14586
- await performRegistration(registry);
14587
- }
14588
- let defaultRegistrationPromise = null;
14589
- let defaultRegistrationError = null;
14590
- async function ensureDefaultRegistration() {
14591
- if (defaultRegistrationError) {
14592
- throw defaultRegistrationError;
14593
- }
14594
- if (!defaultRegistrationPromise) {
14595
- defaultRegistrationError = null;
14596
- defaultRegistrationPromise = performRegistration(factory.Registry).catch((error) => {
14597
- defaultRegistrationError = error;
14598
- defaultRegistrationPromise = null;
14599
- throw error;
14600
- });
14601
- }
14602
- await defaultRegistrationPromise;
14603
- }
14604
- async function ensureRuntimeFactoriesRegistered(registry = factory.Registry) {
14605
- if (registry !== factory.Registry) {
14606
- await performRegistration(registry);
14607
- return;
14608
- }
14609
- await ensureDefaultRegistration();
14610
- }
14611
-
14612
14639
  const NODE_LIKE_FACTORY_BASE_TYPE = 'NodeLikeFactory';
14613
14640
  class NodeLikeFactory extends factory.AbstractResourceFactory {
14614
14641
  static async createNode(config, options = {}) {
@@ -31233,6 +31260,16 @@ var broadcastChannelListenerFactory = /*#__PURE__*/Object.freeze({
31233
31260
  });
31234
31261
 
31235
31262
  installProcessEnvShim();
31263
+ // Always register the plugin directly in the browser.
31264
+ // This bypasses the need for dynamic imports of bare specifiers, which often fail in bundlers.
31265
+ (async () => {
31266
+ try {
31267
+ await runtimePlugin.register();
31268
+ }
31269
+ catch (err) {
31270
+ console.error('[naylence-runtime] Failed to auto-register plugin:', err);
31271
+ }
31272
+ })();
31236
31273
 
31237
31274
  let defaultHttpServerModulePromise$1 = null;
31238
31275
  function getDefaultHttpServerModule$1() {
@@ -37989,31 +38026,104 @@ var traceEmitterProfileFactory = /*#__PURE__*/Object.freeze({
37989
38026
  default: TraceEmitterProfileFactory
37990
38027
  });
37991
38028
 
37992
- let initialized = false;
37993
- const runtimePlugin = {
37994
- name: 'naylence:runtime',
37995
- version: VERSION,
37996
- async register() {
37997
- // console.log('[naylence:runtime] register() called, initialized=', initialized);
37998
- if (initialized) {
37999
- // console.log('[naylence:runtime] already initialized, skipping');
38000
- return;
38029
+ class WebSocketTransportProvisioner {
38030
+ constructor(options) {
38031
+ this.url = options.url;
38032
+ this.ttlSec = options.ttlSec;
38033
+ }
38034
+ async provision(_decision, hello, _fullMetadata, attachToken) {
38035
+ const supportedTransports = hello.supportedTransports;
38036
+ if (Array.isArray(supportedTransports) && supportedTransports.length > 0) {
38037
+ const hasWebSocket = supportedTransports.includes(WebSocketTransportProvisioner.TRANSPORT_TYPE);
38038
+ if (!hasWebSocket) {
38039
+ throw new Error(`Unsupported transports: ${supportedTransports.join(', ')}`);
38040
+ }
38001
38041
  }
38002
- initialized = true;
38003
- // console.log('[naylence:runtime] registering runtime factories...');
38004
- // Register factories from manifest
38005
- await registerRuntimeFactories();
38006
- // Import modules with side-effect registrations (not in manifest)
38007
- await Promise.resolve().then(function () { return websocketTransportProvisioner; });
38008
- // console.log('[naylence:runtime] runtime factories registered');
38009
- },
38010
- };
38011
- const RUNTIME_PLUGIN_SPECIFIER = runtimePlugin.name;
38042
+ let authConfig;
38043
+ if (attachToken) {
38044
+ const tokenProviderConfig = {
38045
+ type: 'StaticTokenProvider',
38046
+ token: attachToken,
38047
+ };
38048
+ authConfig = {
38049
+ type: 'WebSocketSubprotocolAuth',
38050
+ tokenProvider: tokenProviderConfig,
38051
+ };
38052
+ }
38053
+ const grant = normalizeWebSocketConnectionGrant({
38054
+ type: WEBSOCKET_CONNECTION_GRANT_TYPE,
38055
+ purpose: GRANT_PURPOSE_NODE_ATTACH,
38056
+ url: this.url,
38057
+ auth: authConfig,
38058
+ });
38059
+ const result = {
38060
+ connectionGrant: grant,
38061
+ cleanupHandle: null,
38062
+ };
38063
+ if (this.ttlSec !== undefined) {
38064
+ result.metadata = {
38065
+ ...(result.metadata ?? {}),
38066
+ ttlSec: this.ttlSec,
38067
+ };
38068
+ }
38069
+ return result;
38070
+ }
38071
+ async deprovision(_cleanupHandle) {
38072
+ // No-op for stateless WebSocket transport provisioners
38073
+ }
38074
+ }
38075
+ WebSocketTransportProvisioner.TRANSPORT_TYPE = 'websocket';
38076
+ class WebSocketTransportProvisionerFactory extends TransportProvisionerFactory {
38077
+ constructor() {
38078
+ super(...arguments);
38079
+ this.type = 'WebSocketTransportProvisioner';
38080
+ this.isDefault = true;
38081
+ }
38082
+ async create(config) {
38083
+ const options = normalizeConfig(config);
38084
+ return new WebSocketTransportProvisioner(options);
38085
+ }
38086
+ }
38087
+ function normalizeConfig(config) {
38088
+ if (!config) {
38089
+ throw new Error('WebSocketTransportProvisioner requires configuration');
38090
+ }
38091
+ const candidate = config;
38092
+ const typeValue = typeof candidate.type === 'string' ? candidate.type : undefined;
38093
+ if (typeValue !== 'WebSocketTransportProvisioner') {
38094
+ throw new Error(`WebSocketTransportProvisionerFactory expects type "WebSocketTransportProvisioner", got "${typeValue ?? 'undefined'}"`);
38095
+ }
38096
+ const urlValue = candidate.url;
38097
+ if (typeof urlValue !== 'string' || urlValue.trim().length === 0) {
38098
+ throw new Error('WebSocketTransportProvisioner configuration must include a non-empty "url" string');
38099
+ }
38100
+ const ttlCandidate = (() => {
38101
+ const raw = candidate.ttlSec ?? candidate.ttl_sec ?? candidate.ttlSEC;
38102
+ if (typeof raw === 'number') {
38103
+ return raw;
38104
+ }
38105
+ if (typeof raw === 'string') {
38106
+ const parsed = Number(raw.trim());
38107
+ return Number.isFinite(parsed) ? parsed : undefined;
38108
+ }
38109
+ return undefined;
38110
+ })();
38111
+ const options = {
38112
+ url: urlValue.trim(),
38113
+ };
38114
+ if (typeof ttlCandidate === 'number' && Number.isFinite(ttlCandidate)) {
38115
+ options.ttlSec = ttlCandidate;
38116
+ }
38117
+ return options;
38118
+ }
38119
+ factory.registerFactory(TRANSPORT_PROVISIONER_FACTORY_BASE_TYPE, 'WebSocketTransportProvisioner', WebSocketTransportProvisionerFactory, {
38120
+ isDefault: true,
38121
+ });
38012
38122
 
38013
- var plugin = /*#__PURE__*/Object.freeze({
38123
+ var websocketTransportProvisioner = /*#__PURE__*/Object.freeze({
38014
38124
  __proto__: null,
38015
- RUNTIME_PLUGIN_SPECIFIER: RUNTIME_PLUGIN_SPECIFIER,
38016
- default: runtimePlugin
38125
+ WebSocketTransportProvisioner: WebSocketTransportProvisioner,
38126
+ WebSocketTransportProvisionerFactory: WebSocketTransportProvisionerFactory
38017
38127
  });
38018
38128
 
38019
38129
  const logger$8 = getLogger('naylence.fame.connector.default_http_server');
@@ -41410,106 +41520,6 @@ var otelSetup = /*#__PURE__*/Object.freeze({
41410
41520
  setupOtel: setupOtel
41411
41521
  });
41412
41522
 
41413
- class WebSocketTransportProvisioner {
41414
- constructor(options) {
41415
- this.url = options.url;
41416
- this.ttlSec = options.ttlSec;
41417
- }
41418
- async provision(_decision, hello, _fullMetadata, attachToken) {
41419
- const supportedTransports = hello.supportedTransports;
41420
- if (Array.isArray(supportedTransports) && supportedTransports.length > 0) {
41421
- const hasWebSocket = supportedTransports.includes(WebSocketTransportProvisioner.TRANSPORT_TYPE);
41422
- if (!hasWebSocket) {
41423
- throw new Error(`Unsupported transports: ${supportedTransports.join(', ')}`);
41424
- }
41425
- }
41426
- let authConfig;
41427
- if (attachToken) {
41428
- const tokenProviderConfig = {
41429
- type: 'StaticTokenProvider',
41430
- token: attachToken,
41431
- };
41432
- authConfig = {
41433
- type: 'WebSocketSubprotocolAuth',
41434
- tokenProvider: tokenProviderConfig,
41435
- };
41436
- }
41437
- const grant = normalizeWebSocketConnectionGrant({
41438
- type: WEBSOCKET_CONNECTION_GRANT_TYPE,
41439
- purpose: GRANT_PURPOSE_NODE_ATTACH,
41440
- url: this.url,
41441
- auth: authConfig,
41442
- });
41443
- const result = {
41444
- connectionGrant: grant,
41445
- cleanupHandle: null,
41446
- };
41447
- if (this.ttlSec !== undefined) {
41448
- result.metadata = {
41449
- ...(result.metadata ?? {}),
41450
- ttlSec: this.ttlSec,
41451
- };
41452
- }
41453
- return result;
41454
- }
41455
- async deprovision(_cleanupHandle) {
41456
- // No-op for stateless WebSocket transport provisioners
41457
- }
41458
- }
41459
- WebSocketTransportProvisioner.TRANSPORT_TYPE = 'websocket';
41460
- class WebSocketTransportProvisionerFactory extends TransportProvisionerFactory {
41461
- constructor() {
41462
- super(...arguments);
41463
- this.type = 'WebSocketTransportProvisioner';
41464
- this.isDefault = true;
41465
- }
41466
- async create(config) {
41467
- const options = normalizeConfig(config);
41468
- return new WebSocketTransportProvisioner(options);
41469
- }
41470
- }
41471
- function normalizeConfig(config) {
41472
- if (!config) {
41473
- throw new Error('WebSocketTransportProvisioner requires configuration');
41474
- }
41475
- const candidate = config;
41476
- const typeValue = typeof candidate.type === 'string' ? candidate.type : undefined;
41477
- if (typeValue !== 'WebSocketTransportProvisioner') {
41478
- throw new Error(`WebSocketTransportProvisionerFactory expects type "WebSocketTransportProvisioner", got "${typeValue ?? 'undefined'}"`);
41479
- }
41480
- const urlValue = candidate.url;
41481
- if (typeof urlValue !== 'string' || urlValue.trim().length === 0) {
41482
- throw new Error('WebSocketTransportProvisioner configuration must include a non-empty "url" string');
41483
- }
41484
- const ttlCandidate = (() => {
41485
- const raw = candidate.ttlSec ?? candidate.ttl_sec ?? candidate.ttlSEC;
41486
- if (typeof raw === 'number') {
41487
- return raw;
41488
- }
41489
- if (typeof raw === 'string') {
41490
- const parsed = Number(raw.trim());
41491
- return Number.isFinite(parsed) ? parsed : undefined;
41492
- }
41493
- return undefined;
41494
- })();
41495
- const options = {
41496
- url: urlValue.trim(),
41497
- };
41498
- if (typeof ttlCandidate === 'number' && Number.isFinite(ttlCandidate)) {
41499
- options.ttlSec = ttlCandidate;
41500
- }
41501
- return options;
41502
- }
41503
- factory.registerFactory(TRANSPORT_PROVISIONER_FACTORY_BASE_TYPE, 'WebSocketTransportProvisioner', WebSocketTransportProvisionerFactory, {
41504
- isDefault: true,
41505
- });
41506
-
41507
- var websocketTransportProvisioner = /*#__PURE__*/Object.freeze({
41508
- __proto__: null,
41509
- WebSocketTransportProvisioner: WebSocketTransportProvisioner,
41510
- WebSocketTransportProvisionerFactory: WebSocketTransportProvisionerFactory
41511
- });
41512
-
41513
41523
  exports.ADMISSION_CLIENT_FACTORY_BASE_TYPE = ADMISSION_CLIENT_FACTORY_BASE_TYPE;
41514
41524
  exports.ATTACHMENT_KEY_VALIDATOR_FACTORY_BASE_TYPE = ATTACHMENT_KEY_VALIDATOR_FACTORY_BASE_TYPE;
41515
41525
  exports.AUTHORIZER_FACTORY_BASE_TYPE = AUTHORIZER_FACTORY_BASE_TYPE;