aether-agent-sdk 1.0.0 → 1.0.1

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.
Files changed (77) hide show
  1. package/dist/src/agents/AgentRegistry.d.ts +48 -0
  2. package/dist/src/agents/AgentRegistry.d.ts.map +1 -0
  3. package/dist/src/agents/AgentRegistry.js +114 -0
  4. package/dist/src/agents/AgentRegistry.js.map +1 -0
  5. package/dist/src/agents/AnalyzerAgent.d.ts +18 -0
  6. package/dist/src/agents/AnalyzerAgent.d.ts.map +1 -0
  7. package/dist/src/agents/AnalyzerAgent.js +129 -0
  8. package/dist/src/agents/AnalyzerAgent.js.map +1 -0
  9. package/dist/src/agents/IntelligentVerifierAgent.d.ts +46 -0
  10. package/dist/src/agents/IntelligentVerifierAgent.d.ts.map +1 -0
  11. package/dist/src/agents/IntelligentVerifierAgent.js +262 -0
  12. package/dist/src/agents/IntelligentVerifierAgent.js.map +1 -0
  13. package/dist/src/agents/SettlementAgent.d.ts +14 -0
  14. package/dist/src/agents/SettlementAgent.d.ts.map +1 -0
  15. package/dist/src/agents/SettlementAgent.js +146 -0
  16. package/dist/src/agents/SettlementAgent.js.map +1 -0
  17. package/dist/src/agents/SettlementAgentEnhanced.d.ts +33 -0
  18. package/dist/src/agents/SettlementAgentEnhanced.d.ts.map +1 -0
  19. package/dist/src/agents/SettlementAgentEnhanced.js +219 -0
  20. package/dist/src/agents/SettlementAgentEnhanced.js.map +1 -0
  21. package/dist/src/agents/VerifierAgent.d.ts +30 -0
  22. package/dist/src/agents/VerifierAgent.d.ts.map +1 -0
  23. package/dist/src/agents/VerifierAgent.js +181 -0
  24. package/dist/src/agents/VerifierAgent.js.map +1 -0
  25. package/dist/src/agents/index.d.ts +7 -0
  26. package/dist/src/agents/index.d.ts.map +1 -0
  27. package/dist/src/agents/index.js +11 -0
  28. package/dist/src/agents/index.js.map +1 -0
  29. package/dist/src/facilitator/X402FacilitatorServer.d.ts +17 -0
  30. package/dist/src/facilitator/X402FacilitatorServer.d.ts.map +1 -0
  31. package/dist/src/facilitator/X402FacilitatorServer.js +172 -0
  32. package/dist/src/facilitator/X402FacilitatorServer.js.map +1 -0
  33. package/dist/src/facilitator/index.d.ts +7 -0
  34. package/dist/src/facilitator/index.d.ts.map +1 -0
  35. package/dist/src/facilitator/index.js +11 -0
  36. package/dist/src/facilitator/index.js.map +1 -0
  37. package/dist/src/index.d.ts +19 -0
  38. package/dist/src/index.d.ts.map +1 -0
  39. package/dist/src/index.js +39 -0
  40. package/dist/src/index.js.map +1 -0
  41. package/dist/src/modes/HumanInTheLoopMode.d.ts +92 -0
  42. package/dist/src/modes/HumanInTheLoopMode.d.ts.map +1 -0
  43. package/dist/src/modes/HumanInTheLoopMode.js +234 -0
  44. package/dist/src/modes/HumanInTheLoopMode.js.map +1 -0
  45. package/dist/src/modes/index.d.ts +8 -0
  46. package/dist/src/modes/index.d.ts.map +1 -0
  47. package/dist/src/modes/index.js +11 -0
  48. package/dist/src/modes/index.js.map +1 -0
  49. package/dist/src/protocols/A2ANegotiation.d.ts +122 -0
  50. package/dist/src/protocols/A2ANegotiation.d.ts.map +1 -0
  51. package/dist/src/protocols/A2ANegotiation.js +230 -0
  52. package/dist/src/protocols/A2ANegotiation.js.map +1 -0
  53. package/dist/src/protocols/A2AProtocol.d.ts +49 -0
  54. package/dist/src/protocols/A2AProtocol.d.ts.map +1 -0
  55. package/dist/src/protocols/A2AProtocol.js +126 -0
  56. package/dist/src/protocols/A2AProtocol.js.map +1 -0
  57. package/dist/src/protocols/AP2Protocol.d.ts +57 -0
  58. package/dist/src/protocols/AP2Protocol.d.ts.map +1 -0
  59. package/dist/src/protocols/AP2Protocol.js +121 -0
  60. package/dist/src/protocols/AP2Protocol.js.map +1 -0
  61. package/dist/src/protocols/index.d.ts +10 -0
  62. package/dist/src/protocols/index.d.ts.map +1 -0
  63. package/dist/src/protocols/index.js +15 -0
  64. package/dist/src/protocols/index.js.map +1 -0
  65. package/dist/src/services/index.d.ts +8 -0
  66. package/dist/src/services/index.d.ts.map +1 -0
  67. package/dist/src/services/index.js +13 -0
  68. package/dist/src/services/index.js.map +1 -0
  69. package/dist/src/utils/env.d.ts +15 -0
  70. package/dist/src/utils/env.d.ts.map +1 -0
  71. package/dist/src/utils/env.js +39 -0
  72. package/dist/src/utils/env.js.map +1 -0
  73. package/dist/src/utils/index.d.ts +7 -0
  74. package/dist/src/utils/index.d.ts.map +1 -0
  75. package/dist/src/utils/index.js +12 -0
  76. package/dist/src/utils/index.js.map +1 -0
  77. package/package.json +1 -1
@@ -0,0 +1,48 @@
1
+ /**
2
+ * HCS-10 Agent Registry
3
+ * Manages agent registration, discovery, and metadata for HCS-10 compatible agents
4
+ */
5
+ export interface AgentMetadata {
6
+ agentId: string;
7
+ agentName: string;
8
+ agentType: 'analyzer' | 'verifier' | 'settlement';
9
+ capabilities: string[];
10
+ supportedMessageTypes: string[];
11
+ topicId: string;
12
+ status: 'active' | 'inactive';
13
+ registrationTime?: number;
14
+ }
15
+ export declare class AgentRegistry {
16
+ private agents;
17
+ /**
18
+ * Register an agent in the local registry
19
+ */
20
+ registerAgent(metadata: AgentMetadata): void;
21
+ /**
22
+ * Get agent metadata by ID
23
+ */
24
+ getAgent(agentId: string): AgentMetadata | undefined;
25
+ /**
26
+ * Get all registered agents
27
+ */
28
+ getAllAgents(): AgentMetadata[];
29
+ /**
30
+ * Discover agents by type
31
+ */
32
+ discoverAgentsByType(type: string): AgentMetadata[];
33
+ /**
34
+ * Discover agents by capability
35
+ */
36
+ discoverAgentsByCapability(capability: string): AgentMetadata[];
37
+ /**
38
+ * Check agent status
39
+ */
40
+ isAgentActive(agentId: string): boolean;
41
+ /**
42
+ * Get agent summary
43
+ */
44
+ getSummary(): string;
45
+ }
46
+ export declare const globalAgentRegistry: AgentRegistry;
47
+ export declare function initializeHCS10Agents(): void;
48
+ //# sourceMappingURL=AgentRegistry.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AgentRegistry.d.ts","sourceRoot":"","sources":["../../../src/agents/AgentRegistry.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAQH,MAAM,WAAW,aAAa;IAC5B,OAAO,EAAE,MAAM,CAAA;IACf,SAAS,EAAE,MAAM,CAAA;IACjB,SAAS,EAAE,UAAU,GAAG,UAAU,GAAG,YAAY,CAAA;IACjD,YAAY,EAAE,MAAM,EAAE,CAAA;IACtB,qBAAqB,EAAE,MAAM,EAAE,CAAA;IAC/B,OAAO,EAAE,MAAM,CAAA;IACf,MAAM,EAAE,QAAQ,GAAG,UAAU,CAAA;IAC7B,gBAAgB,CAAC,EAAE,MAAM,CAAA;CAC1B;AAED,qBAAa,aAAa;IACxB,OAAO,CAAC,MAAM,CAAwC;IAEtD;;OAEG;IACH,aAAa,CAAC,QAAQ,EAAE,aAAa,GAAG,IAAI;IAQ5C;;OAEG;IACH,QAAQ,CAAC,OAAO,EAAE,MAAM,GAAG,aAAa,GAAG,SAAS;IAIpD;;OAEG;IACH,YAAY,IAAI,aAAa,EAAE;IAI/B;;OAEG;IACH,oBAAoB,CAAC,IAAI,EAAE,MAAM,GAAG,aAAa,EAAE;IAInD;;OAEG;IACH,0BAA0B,CAAC,UAAU,EAAE,MAAM,GAAG,aAAa,EAAE;IAM/D;;OAEG;IACH,aAAa,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO;IAKvC;;OAEG;IACH,UAAU,IAAI,MAAM;CAQrB;AAGD,eAAO,MAAM,mBAAmB,eAAsB,CAAA;AAGtD,wBAAgB,qBAAqB,IAAI,IAAI,CA6C5C"}
@@ -0,0 +1,114 @@
1
+ "use strict";
2
+ /**
3
+ * HCS-10 Agent Registry
4
+ * Manages agent registration, discovery, and metadata for HCS-10 compatible agents
5
+ */
6
+ var __importDefault = (this && this.__importDefault) || function (mod) {
7
+ return (mod && mod.__esModule) ? mod : { "default": mod };
8
+ };
9
+ Object.defineProperty(exports, "__esModule", { value: true });
10
+ exports.globalAgentRegistry = exports.AgentRegistry = void 0;
11
+ exports.initializeHCS10Agents = initializeHCS10Agents;
12
+ const env_1 = require("../utils/env");
13
+ const chalk_1 = __importDefault(require("chalk"));
14
+ (0, env_1.loadEnvIfNeeded)();
15
+ class AgentRegistry {
16
+ agents = new Map();
17
+ /**
18
+ * Register an agent in the local registry
19
+ */
20
+ registerAgent(metadata) {
21
+ this.agents.set(metadata.agentId, metadata);
22
+ console.log(chalk_1.default.green(`✅ Registered agent: ${metadata.agentName} (${metadata.agentId})`));
23
+ console.log(chalk_1.default.gray(` Type: ${metadata.agentType}`));
24
+ console.log(chalk_1.default.gray(` Capabilities: ${metadata.capabilities.join(', ')}`));
25
+ console.log(chalk_1.default.gray(` Topic: ${metadata.topicId}`));
26
+ }
27
+ /**
28
+ * Get agent metadata by ID
29
+ */
30
+ getAgent(agentId) {
31
+ return this.agents.get(agentId);
32
+ }
33
+ /**
34
+ * Get all registered agents
35
+ */
36
+ getAllAgents() {
37
+ return Array.from(this.agents.values());
38
+ }
39
+ /**
40
+ * Discover agents by type
41
+ */
42
+ discoverAgentsByType(type) {
43
+ return Array.from(this.agents.values()).filter(agent => agent.agentType === type);
44
+ }
45
+ /**
46
+ * Discover agents by capability
47
+ */
48
+ discoverAgentsByCapability(capability) {
49
+ return Array.from(this.agents.values()).filter(agent => agent.capabilities.includes(capability));
50
+ }
51
+ /**
52
+ * Check agent status
53
+ */
54
+ isAgentActive(agentId) {
55
+ const agent = this.agents.get(agentId);
56
+ return agent?.status === 'active';
57
+ }
58
+ /**
59
+ * Get agent summary
60
+ */
61
+ getSummary() {
62
+ const agents = this.getAllAgents();
63
+ return chalk_1.default.blue(`📊 Agent Registry: ${agents.length} agents registered\n` +
64
+ agents.map(agent => ` ${agent.agentName} (${agent.agentType}) - ${agent.status}`).join('\n'));
65
+ }
66
+ }
67
+ exports.AgentRegistry = AgentRegistry;
68
+ // Global registry instance
69
+ exports.globalAgentRegistry = new AgentRegistry();
70
+ // Register predefined agents from environment
71
+ function initializeHCS10Agents() {
72
+ // Analyzer Agent
73
+ if (process.env.ANALYZER_AGENT_ID && process.env.ANALYZER_TOPIC_ID) {
74
+ exports.globalAgentRegistry.registerAgent({
75
+ agentId: process.env.ANALYZER_AGENT_ID,
76
+ agentName: 'AnalyzerAgent',
77
+ agentType: 'analyzer',
78
+ capabilities: ['account-analysis', 'threshold-evaluation', 'proposal-generation'],
79
+ supportedMessageTypes: ['analysis_proposal', 'settlement_complete'],
80
+ topicId: process.env.ANALYZER_TOPIC_ID,
81
+ status: 'active',
82
+ registrationTime: Date.now()
83
+ });
84
+ }
85
+ // Verifier Agent
86
+ if (process.env.VERIFIER_AGENT_ID && process.env.VERIFIER_TOPIC_ID) {
87
+ exports.globalAgentRegistry.registerAgent({
88
+ agentId: process.env.VERIFIER_AGENT_ID,
89
+ agentName: 'VerifierAgent',
90
+ agentType: 'verifier',
91
+ capabilities: ['proposal-validation', 'approval-decision', 'business-logic'],
92
+ supportedMessageTypes: ['verification_result', 'analysis_proposal'],
93
+ topicId: process.env.VERIFIER_TOPIC_ID,
94
+ status: 'active',
95
+ registrationTime: Date.now()
96
+ });
97
+ }
98
+ // Settlement Agent
99
+ if (process.env.SETTLEMENT_AGENT_ID && process.env.SETTLEMENT_TOPIC_ID) {
100
+ exports.globalAgentRegistry.registerAgent({
101
+ agentId: process.env.SETTLEMENT_AGENT_ID,
102
+ agentName: 'SettlementAgent',
103
+ agentType: 'settlement',
104
+ capabilities: ['x402-payment', 'cross-chain-settlement', 'usdc-transfer'],
105
+ supportedMessageTypes: ['verification_result', 'settlement_complete'],
106
+ topicId: process.env.SETTLEMENT_TOPIC_ID,
107
+ status: 'active',
108
+ registrationTime: Date.now()
109
+ });
110
+ }
111
+ console.log(chalk_1.default.bold.green('\n🎯 HCS-10 Agents Initialized\n'));
112
+ console.log(exports.globalAgentRegistry.getSummary());
113
+ }
114
+ //# sourceMappingURL=AgentRegistry.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AgentRegistry.js","sourceRoot":"","sources":["../../../src/agents/AgentRegistry.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,18 @@
1
+ import { HCS10Client } from '@hashgraphonline/standards-agent-kit';
2
+ import { HCS10ConnectionManager } from '../protocols/HCS10ConnectionManager';
3
+ export declare class AnalyzerAgent {
4
+ private hcsClient;
5
+ private hederaClient;
6
+ private connectionManager?;
7
+ private readonly MIRROR_NODE_URL;
8
+ constructor();
9
+ init(): Promise<void>;
10
+ queryAccount(accountId: string): Promise<any>;
11
+ queryAccountViaMirror(accountId: string): Promise<any>;
12
+ getHcsClient(): HCS10Client;
13
+ /**
14
+ * Get connection manager instance (if initialized)
15
+ */
16
+ getConnectionManager(): HCS10ConnectionManager | undefined;
17
+ }
18
+ //# sourceMappingURL=AnalyzerAgent.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AnalyzerAgent.d.ts","sourceRoot":"","sources":["../../../src/agents/AnalyzerAgent.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,sCAAsC,CAAA;AAElE,OAAO,EAAE,sBAAsB,EAAE,MAAM,qCAAqC,CAAA;AAO5E,qBAAa,aAAa;IACxB,OAAO,CAAC,SAAS,CAAa;IAC9B,OAAO,CAAC,YAAY,CAAQ;IAC5B,OAAO,CAAC,iBAAiB,CAAC,CAAwB;IAClD,OAAO,CAAC,QAAQ,CAAC,eAAe,CAA0C;;IAmDpE,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC;IAuBrB,YAAY,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,GAAG,CAAC;IA0B7C,qBAAqB,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,GAAG,CAAC;IAgB5D,YAAY,IAAI,WAAW;IAI3B;;OAEG;IACH,oBAAoB,IAAI,sBAAsB,GAAG,SAAS;CAG3D"}
@@ -0,0 +1,129 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.AnalyzerAgent = void 0;
7
+ const standards_agent_kit_1 = require("@hashgraphonline/standards-agent-kit");
8
+ const sdk_1 = require("@hashgraph/sdk");
9
+ const HCS10ConnectionManager_1 = require("../protocols/HCS10ConnectionManager");
10
+ const axios_1 = __importDefault(require("axios"));
11
+ const dotenv_1 = __importDefault(require("dotenv"));
12
+ // Load environment variables
13
+ dotenv_1.default.config();
14
+ class AnalyzerAgent {
15
+ hcsClient;
16
+ hederaClient;
17
+ connectionManager;
18
+ MIRROR_NODE_URL = 'https://testnet.mirrornode.hedera.com';
19
+ constructor() {
20
+ // Get agent credentials from environment variables
21
+ const agentId = process.env.ANALYZER_AGENT_ID;
22
+ const privateKey = process.env.ANALYZER_PRIVATE_KEY;
23
+ if (!agentId || !privateKey) {
24
+ throw new Error('Missing required environment variables: ANALYZER_AGENT_ID and ANALYZER_PRIVATE_KEY');
25
+ }
26
+ // Check if we have a placeholder private key
27
+ if (privateKey.startsWith('placeholder-key-for-')) {
28
+ console.warn('⚠️ Using placeholder private key. Agent registration may not have captured the actual private key.');
29
+ console.warn('⚠️ For now, we\'ll use the main Hedera account for testing.');
30
+ // Use the main Hedera account credentials for testing
31
+ const mainAccountId = process.env.HEDERA_ACCOUNT_ID;
32
+ const mainPrivateKey = process.env.HEDERA_PRIVATE_KEY;
33
+ if (!mainAccountId || !mainPrivateKey) {
34
+ throw new Error('Missing main Hedera credentials for fallback');
35
+ }
36
+ this.hederaClient = sdk_1.Client.forTestnet();
37
+ this.hederaClient.setOperator(sdk_1.AccountId.fromString(mainAccountId), mainPrivateKey);
38
+ // Initialize HCS10Client with main account for now
39
+ this.hcsClient = new standards_agent_kit_1.HCS10Client(mainAccountId, mainPrivateKey, 'testnet');
40
+ // Initialize connection manager (optional)
41
+ const useConnections = process.env.USE_HCS10_CONNECTIONS === 'true';
42
+ if (useConnections) {
43
+ this.connectionManager = new HCS10ConnectionManager_1.HCS10ConnectionManager(this.hcsClient, mainAccountId);
44
+ }
45
+ }
46
+ else {
47
+ // Initialize HCS10Client with actual agent credentials
48
+ this.hcsClient = new standards_agent_kit_1.HCS10Client(agentId, privateKey, 'testnet');
49
+ // Also initialize Hedera client for direct queries
50
+ this.hederaClient = sdk_1.Client.forTestnet();
51
+ this.hederaClient.setOperator(sdk_1.AccountId.fromString(agentId), privateKey);
52
+ // Initialize connection manager (optional)
53
+ const useConnections = process.env.USE_HCS10_CONNECTIONS === 'true';
54
+ if (useConnections) {
55
+ this.connectionManager = new HCS10ConnectionManager_1.HCS10ConnectionManager(this.hcsClient, agentId);
56
+ }
57
+ }
58
+ }
59
+ async init() {
60
+ try {
61
+ // Log initialization success
62
+ console.log('🔗 AnalyzerAgent initialized for Hedera testnet');
63
+ console.log(`📡 Mirror node URL: ${this.MIRROR_NODE_URL}`);
64
+ console.log(`🆔 Agent ID: ${process.env.ANALYZER_AGENT_ID}`);
65
+ // Test connection by querying our own account
66
+ const agentId = process.env.ANALYZER_AGENT_ID;
67
+ if (agentId) {
68
+ try {
69
+ const accountInfo = await this.queryAccount(agentId);
70
+ console.log(`✅ Agent account verified: ${accountInfo.balance} tinybars`);
71
+ }
72
+ catch (error) {
73
+ console.warn(`⚠️ Could not verify agent account ${agentId}:`, error.message);
74
+ }
75
+ }
76
+ }
77
+ catch (error) {
78
+ console.error('❌ Failed to initialize AnalyzerAgent:', error);
79
+ throw error;
80
+ }
81
+ }
82
+ async queryAccount(accountId) {
83
+ try {
84
+ console.log(`🔍 Querying account: ${accountId}`);
85
+ // Query account info using Hedera SDK
86
+ const accountInfo = await new sdk_1.AccountInfoQuery()
87
+ .setAccountId(accountId)
88
+ .execute(this.hederaClient);
89
+ console.log(`✅ Account ${accountId} found`);
90
+ console.log(`💰 Balance: ${accountInfo.balance} tinybars`);
91
+ console.log(`🔑 Key: ${accountInfo.key?.toString()}`);
92
+ return {
93
+ accountId: accountId,
94
+ balance: accountInfo.balance.toString(),
95
+ key: accountInfo.key?.toString(),
96
+ isDeleted: accountInfo.isDeleted,
97
+ autoRenewPeriod: accountInfo.autoRenewPeriod?.toString()
98
+ };
99
+ }
100
+ catch (error) {
101
+ console.error(`❌ Failed to query account ${accountId}:`, error);
102
+ throw error;
103
+ }
104
+ }
105
+ async queryAccountViaMirror(accountId) {
106
+ try {
107
+ console.log(`🔍 Querying account via mirror node: ${accountId}`);
108
+ const response = await axios_1.default.get(`${this.MIRROR_NODE_URL}/api/v1/accounts/${accountId}`);
109
+ console.log(`✅ Account ${accountId} found via mirror node`);
110
+ console.log(`💰 Balance: ${response.data.balance?.balance} tinybars`);
111
+ return response.data;
112
+ }
113
+ catch (error) {
114
+ console.error(`❌ Failed to query account ${accountId} via mirror node:`, error);
115
+ throw error;
116
+ }
117
+ }
118
+ getHcsClient() {
119
+ return this.hcsClient;
120
+ }
121
+ /**
122
+ * Get connection manager instance (if initialized)
123
+ */
124
+ getConnectionManager() {
125
+ return this.connectionManager;
126
+ }
127
+ }
128
+ exports.AnalyzerAgent = AnalyzerAgent;
129
+ //# sourceMappingURL=AnalyzerAgent.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AnalyzerAgent.js","sourceRoot":"","sources":["../../../src/agents/AnalyzerAgent.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,46 @@
1
+ /**
2
+ * Intelligent Verifier Agent with LLM Reasoning
3
+ *
4
+ * This agent uses OpenAI LLM to make intelligent decisions about:
5
+ * - Invoice validation and fraud detection
6
+ * - Payment approval with context-aware reasoning
7
+ * - Negotiation with counter-offers
8
+ * - Anomaly detection in transactions
9
+ *
10
+ * Demonstrates the power of AI + blockchain for autonomous decisions
11
+ */
12
+ export declare class IntelligentVerifierAgent {
13
+ private llm?;
14
+ private hcsClient?;
15
+ private agentId;
16
+ private useLLM;
17
+ constructor();
18
+ /**
19
+ * Intelligent invoice validation using LLM reasoning
20
+ */
21
+ analyzeInvoiceWithReasoning(invoice: any): Promise<{
22
+ approved: boolean;
23
+ reasoning: string;
24
+ confidence: number;
25
+ riskFactors: string[];
26
+ }>;
27
+ /**
28
+ * Parse LLM response (handles both JSON and plain text)
29
+ */
30
+ private parseLLMResponse;
31
+ /**
32
+ * Fallback rule-based analysis
33
+ */
34
+ private analyzeInvoiceRuleBased;
35
+ /**
36
+ * Intelligent fraud detection
37
+ */
38
+ detectFraud(transaction: any): Promise<{
39
+ isFraud: boolean;
40
+ riskScore: number;
41
+ reasoning: string;
42
+ recommendations: string[];
43
+ }>;
44
+ init(): Promise<void>;
45
+ }
46
+ //# sourceMappingURL=IntelligentVerifierAgent.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"IntelligentVerifierAgent.d.ts","sourceRoot":"","sources":["../../../src/agents/IntelligentVerifierAgent.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;GAUG;AASH,qBAAa,wBAAwB;IACnC,OAAO,CAAC,GAAG,CAAC,CAAY;IACxB,OAAO,CAAC,SAAS,CAAC,CAAa;IAC/B,OAAO,CAAC,OAAO,CAAQ;IACvB,OAAO,CAAC,MAAM,CAAS;;IAsCvB;;OAEG;IACG,2BAA2B,CAAC,OAAO,EAAE,GAAG,GAAG,OAAO,CAAC;QACvD,QAAQ,EAAE,OAAO,CAAA;QACjB,SAAS,EAAE,MAAM,CAAA;QACjB,UAAU,EAAE,MAAM,CAAA;QAClB,WAAW,EAAE,MAAM,EAAE,CAAA;KACtB,CAAC;IAqDF;;OAEG;IACH,OAAO,CAAC,gBAAgB;IAqCxB;;OAEG;IACH,OAAO,CAAC,uBAAuB;IAoD/B;;OAEG;IACG,WAAW,CAAC,WAAW,EAAE,GAAG,GAAG,OAAO,CAAC;QAC3C,OAAO,EAAE,OAAO,CAAA;QAChB,SAAS,EAAE,MAAM,CAAA;QACjB,SAAS,EAAE,MAAM,CAAA;QACjB,eAAe,EAAE,MAAM,EAAE,CAAA;KAC1B,CAAC;IAmEI,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC;CAW5B"}
@@ -0,0 +1,262 @@
1
+ "use strict";
2
+ /**
3
+ * Intelligent Verifier Agent with LLM Reasoning
4
+ *
5
+ * This agent uses OpenAI LLM to make intelligent decisions about:
6
+ * - Invoice validation and fraud detection
7
+ * - Payment approval with context-aware reasoning
8
+ * - Negotiation with counter-offers
9
+ * - Anomaly detection in transactions
10
+ *
11
+ * Demonstrates the power of AI + blockchain for autonomous decisions
12
+ */
13
+ var __importDefault = (this && this.__importDefault) || function (mod) {
14
+ return (mod && mod.__esModule) ? mod : { "default": mod };
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ exports.IntelligentVerifierAgent = void 0;
18
+ const openai_1 = require("@langchain/openai");
19
+ const standards_agent_kit_1 = require("@hashgraphonline/standards-agent-kit");
20
+ const env_1 = require("../utils/env");
21
+ const chalk_1 = __importDefault(require("chalk"));
22
+ (0, env_1.loadEnvIfNeeded)();
23
+ class IntelligentVerifierAgent {
24
+ llm;
25
+ hcsClient;
26
+ agentId;
27
+ useLLM;
28
+ constructor() {
29
+ const apiKey = process.env.OPENAI_API_KEY;
30
+ const agentId = process.env.VERIFIER_AGENT_ID || process.env.HEDERA_ACCOUNT_ID;
31
+ const privateKey = process.env.VERIFIER_PRIVATE_KEY || process.env.HEDERA_PRIVATE_KEY;
32
+ this.agentId = agentId || 'demo-agent';
33
+ // Try to initialize HCS client, but don't fail if credentials are missing
34
+ if (agentId && privateKey) {
35
+ try {
36
+ this.hcsClient = new standards_agent_kit_1.HCS10Client(agentId, privateKey, 'testnet');
37
+ }
38
+ catch (error) {
39
+ // Ignore initialization errors - we'll use LLM without HCS
40
+ console.log(chalk_1.default.yellow('⚠️ Could not initialize HCS client'));
41
+ }
42
+ }
43
+ this.useLLM = !!apiKey;
44
+ // Initialize LLM only if API key is provided
45
+ if (apiKey) {
46
+ try {
47
+ this.llm = new openai_1.ChatOpenAI({
48
+ model: 'gpt-4o-mini',
49
+ temperature: 0.2,
50
+ maxTokens: 500
51
+ });
52
+ console.log(chalk_1.default.green('✅ Intelligent Verifier Agent initialized with LLM reasoning'));
53
+ }
54
+ catch (error) {
55
+ console.log(chalk_1.default.yellow('⚠️ LLM initialization failed - falling back to rule-based validation'));
56
+ }
57
+ }
58
+ else {
59
+ console.log(chalk_1.default.yellow('⚠️ No OpenAI API key - falling back to rule-based validation'));
60
+ }
61
+ }
62
+ /**
63
+ * Intelligent invoice validation using LLM reasoning
64
+ */
65
+ async analyzeInvoiceWithReasoning(invoice) {
66
+ if (!this.useLLM || !this.llm) {
67
+ // Fallback to rule-based validation
68
+ return this.analyzeInvoiceRuleBased(invoice);
69
+ }
70
+ try {
71
+ console.log(chalk_1.default.blue('🤖 LLM analyzing invoice with intelligent reasoning...'));
72
+ const systemPrompt = `You are an intelligent financial agent analyzing invoices for automated payment.
73
+ Your task is to validate the invoice, detect potential fraud, and approve or reject based on risk assessment.
74
+
75
+ Business Rules:
76
+ - Amounts < $500: Usually approved automatically
77
+ - Amounts $500-$2000: Require scrutiny
78
+ - Amounts > $2000: Require detailed analysis
79
+
80
+ Common Red Flags: Unusual patterns, unfamiliar vendors, round numbers without context, inconsistent metadata.
81
+
82
+ Respond in JSON format: {approved: boolean, confidence: 0-100, reasoning: string, riskFactors: [string]}`;
83
+ const userPrompt = `Analyze this invoice:
84
+ ID: ${invoice.invoiceId}
85
+ Amount: $${invoice.amountUSD}
86
+ Description: ${invoice.description}
87
+ Vendor: ${invoice.vendorAccountId}
88
+ Due Date: ${invoice.dueDate.toISOString()}
89
+ Category: ${invoice.category}
90
+ Urgency: ${invoice.urgency}`;
91
+ const response = await this.llm.invoke([
92
+ { role: 'system', content: systemPrompt },
93
+ { role: 'user', content: userPrompt }
94
+ ]);
95
+ const reasoning = response.content;
96
+ // Parse LLM response
97
+ let result = this.parseLLMResponse(reasoning);
98
+ console.log(chalk_1.default.green('✅ LLM analysis complete'));
99
+ console.log(chalk_1.default.blue(`📊 Decision: ${result.approved ? 'APPROVED' : 'REJECTED'}`));
100
+ console.log(chalk_1.default.blue(`🎯 Confidence: ${result.confidence}%`));
101
+ console.log(chalk_1.default.blue(`💡 Reasoning: ${result.reasoning}`));
102
+ return result;
103
+ }
104
+ catch (error) {
105
+ console.error(chalk_1.default.red(`❌ LLM analysis failed: ${error.message}`));
106
+ return this.analyzeInvoiceRuleBased(invoice);
107
+ }
108
+ }
109
+ /**
110
+ * Parse LLM response (handles both JSON and plain text)
111
+ */
112
+ parseLLMResponse(reasoning) {
113
+ try {
114
+ // Try to extract JSON
115
+ const jsonMatch = reasoning.match(/\{[\s\S]*\}/);
116
+ if (jsonMatch) {
117
+ const parsed = JSON.parse(jsonMatch[0]);
118
+ return {
119
+ approved: parsed.approved !== false,
120
+ reasoning: parsed.reasoning || 'No reasoning provided',
121
+ confidence: parsed.confidence || 50,
122
+ riskFactors: parsed.riskFactors || []
123
+ };
124
+ }
125
+ // If no JSON, parse text response
126
+ const approved = reasoning.toLowerCase().includes('approve') && !reasoning.toLowerCase().includes('not approve');
127
+ return {
128
+ approved,
129
+ reasoning,
130
+ confidence: approved ? 75 : 25,
131
+ riskFactors: []
132
+ };
133
+ }
134
+ catch (error) {
135
+ return {
136
+ approved: true,
137
+ reasoning: reasoning,
138
+ confidence: 50,
139
+ riskFactors: []
140
+ };
141
+ }
142
+ }
143
+ /**
144
+ * Fallback rule-based analysis
145
+ */
146
+ analyzeInvoiceRuleBased(invoice) {
147
+ const riskFactors = [];
148
+ let approved = true;
149
+ // Check amount
150
+ if (invoice.amountUSD > 2000) {
151
+ riskFactors.push('High amount (>$2000)');
152
+ approved = false;
153
+ return {
154
+ approved: false,
155
+ reasoning: 'Amount exceeds rule-based threshold of $2000',
156
+ confidence: 80,
157
+ riskFactors
158
+ };
159
+ }
160
+ if (invoice.amountUSD > 500) {
161
+ riskFactors.push('Medium amount ($500-$2000)');
162
+ }
163
+ // Check if vendor account is provided
164
+ if (!invoice.vendorAccountId || invoice.vendorAccountId === '0.0.XXXXXX') {
165
+ approved = false;
166
+ riskFactors.push('Invalid vendor account');
167
+ return {
168
+ approved: false,
169
+ reasoning: 'Invalid or missing vendor account ID',
170
+ confidence: 90,
171
+ riskFactors
172
+ };
173
+ }
174
+ // Check description
175
+ if (!invoice.description || invoice.description.length < 10) {
176
+ riskFactors.push('Insufficient description');
177
+ }
178
+ return {
179
+ approved,
180
+ reasoning: approved
181
+ ? `Rule-based validation passed. Amount: $${invoice.amountUSD} within acceptable range.`
182
+ : 'Rule-based validation failed due to risk factors',
183
+ confidence: 70,
184
+ riskFactors
185
+ };
186
+ }
187
+ /**
188
+ * Intelligent fraud detection
189
+ */
190
+ async detectFraud(transaction) {
191
+ if (!this.useLLM || !this.llm) {
192
+ return {
193
+ isFraud: false,
194
+ riskScore: 0,
195
+ reasoning: 'LLM not available for fraud detection',
196
+ recommendations: []
197
+ };
198
+ }
199
+ try {
200
+ console.log(chalk_1.default.blue('🔍 LLM checking for fraud patterns...'));
201
+ const systemPrompt = `You are a fraud detection agent. Analyze transactions for suspicious patterns.
202
+
203
+ VALID: Hedera account IDs (0.0.XXXXXX), reasonable amounts for B2B ($1-$10000), typical business descriptions.
204
+
205
+ RED FLAGS:
206
+ - Amounts outside $1-$10000 range
207
+ - Vague or suspicious descriptions ("urgent payment needed")
208
+ - Multiple rapid transactions in short time
209
+ - Amounts with suspicious patterns (e.g., $1234.56)
210
+
211
+ Respond in JSON only: {"isFraud": false, "riskScore": 0-100, "reasoning": "brief explanation", "recommendations": []}`;
212
+ const userPrompt = `Transaction:
213
+ Amount: $${transaction.amount}
214
+ Vendor: ${transaction.vendorAccountId}
215
+ Description: ${transaction.description}
216
+ Timestamp: ${transaction.timestamp}`;
217
+ const response = await this.llm.invoke([
218
+ { role: 'system', content: systemPrompt },
219
+ { role: 'user', content: userPrompt }
220
+ ]);
221
+ const reasoning = response.content;
222
+ // Parse response
223
+ const jsonMatch = reasoning.match(/\{[\s\S]*\}/);
224
+ if (jsonMatch) {
225
+ const parsed = JSON.parse(jsonMatch[0]);
226
+ return {
227
+ isFraud: parsed.isFraud || false,
228
+ riskScore: parsed.riskScore || 0,
229
+ reasoning: parsed.reasoning || 'No fraud detected',
230
+ recommendations: parsed.recommendations || []
231
+ };
232
+ }
233
+ return {
234
+ isFraud: false,
235
+ riskScore: 0,
236
+ reasoning,
237
+ recommendations: []
238
+ };
239
+ }
240
+ catch (error) {
241
+ console.error(chalk_1.default.red(`❌ Fraud detection failed: ${error.message}`));
242
+ return {
243
+ isFraud: false,
244
+ riskScore: 0,
245
+ reasoning: 'Fraud detection unavailable',
246
+ recommendations: []
247
+ };
248
+ }
249
+ }
250
+ async init() {
251
+ const topicId = process.env.VERIFIER_TOPIC_ID;
252
+ if (!topicId) {
253
+ console.log(chalk_1.default.yellow('⚠️ No topic ID - agent will not poll'));
254
+ return;
255
+ }
256
+ console.log(chalk_1.default.green('✅ Intelligent Verifier Agent ready'));
257
+ console.log(chalk_1.default.blue(`📡 Topic ID: ${topicId}`));
258
+ console.log(chalk_1.default.blue(`🤖 LLM Reasoning: ${this.useLLM ? 'Enabled' : 'Disabled'}`));
259
+ }
260
+ }
261
+ exports.IntelligentVerifierAgent = IntelligentVerifierAgent;
262
+ //# sourceMappingURL=IntelligentVerifierAgent.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"IntelligentVerifierAgent.js","sourceRoot":"","sources":["../../../src/agents/IntelligentVerifierAgent.ts"],"names":[],"mappings":"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"}