openbroker 1.1.1 → 1.1.2

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/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "openbroker",
3
- "version": "1.1.1",
3
+ "version": "1.1.2",
4
4
  "description": "Hyperliquid trading CLI - execute orders, manage positions, and run trading strategies",
5
5
  "type": "module",
6
6
  "bin": {
@@ -53,12 +53,21 @@ async function loadConventionObservers(log: AutomationLogger): Promise<Automatio
53
53
  const observer = typeof exported === 'function' ? exported() : exported;
54
54
  if (observer && typeof observer === 'object') {
55
55
  observers.push(observer as AutomationAuditObserver);
56
- log.debug(`Loaded audit observer: ${name}`);
56
+ log.info(`[audit-observer] loaded: ${name}`);
57
+ } else {
58
+ // Package resolved but its factory returned null/undefined — typically
59
+ // because required env (e.g. OB_DASHBOARD_URL) is missing. Surface this
60
+ // so operators don't silently lose telemetry.
61
+ log.warn(
62
+ `[audit-observer] ${name} resolved but factory returned no observer — check the package's required env vars`
63
+ );
57
64
  }
58
65
  } catch (err) {
59
66
  const code = (err as NodeJS.ErrnoException | undefined)?.code;
60
- if (code !== 'ERR_MODULE_NOT_FOUND' && code !== 'MODULE_NOT_FOUND') {
61
- log.warn(`Failed to load audit observer "${name}": ${err instanceof Error ? err.message : String(err)}`);
67
+ if (code === 'ERR_MODULE_NOT_FOUND' || code === 'MODULE_NOT_FOUND') {
68
+ log.info(`[audit-observer] ${name} not installed skipping (install it alongside openbroker to forward telemetry)`);
69
+ } else {
70
+ log.warn(`[audit-observer] failed to load "${name}": ${err instanceof Error ? err.message : String(err)}`);
62
71
  }
63
72
  }
64
73
  }