safehands-pharos 1.2.0 → 1.2.4
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/.env.example +26 -0
- package/README.md +311 -350
- package/contracts/RiskRegistry.json +75 -1
- package/contracts/RiskRegistry.sol +29 -1
- package/dist/cli.d.ts +6 -0
- package/dist/cli.d.ts.map +1 -0
- package/dist/cli.js +91 -0
- package/dist/cli.js.map +1 -0
- package/dist/demo.d.ts +2 -0
- package/dist/demo.d.ts.map +1 -0
- package/dist/demo.js +172 -0
- package/dist/demo.js.map +1 -0
- package/dist/index.js +181 -169
- package/dist/index.js.map +1 -1
- package/dist/init.d.ts +2 -0
- package/dist/init.d.ts.map +1 -0
- package/dist/init.js +66 -0
- package/dist/init.js.map +1 -0
- package/dist/lib/constants.d.ts +122 -7
- package/dist/lib/constants.d.ts.map +1 -1
- package/dist/lib/constants.js +139 -13
- package/dist/lib/constants.js.map +1 -1
- package/dist/lib/dodoApi.d.ts +14 -0
- package/dist/lib/dodoApi.d.ts.map +1 -1
- package/dist/lib/dodoApi.js +78 -22
- package/dist/lib/dodoApi.js.map +1 -1
- package/dist/lib/http.d.ts +15 -0
- package/dist/lib/http.d.ts.map +1 -0
- package/dist/lib/http.js +119 -0
- package/dist/lib/http.js.map +1 -0
- package/dist/lib/pharosClient.d.ts +4 -3
- package/dist/lib/pharosClient.d.ts.map +1 -1
- package/dist/lib/pharosClient.js +8 -5
- package/dist/lib/pharosClient.js.map +1 -1
- package/dist/lib/policy/actionPolicyEngine.d.ts +54 -0
- package/dist/lib/policy/actionPolicyEngine.d.ts.map +1 -0
- package/dist/lib/policy/actionPolicyEngine.js +213 -0
- package/dist/lib/policy/actionPolicyEngine.js.map +1 -0
- package/dist/lib/signer/index.d.ts +25 -0
- package/dist/lib/signer/index.d.ts.map +1 -0
- package/dist/lib/signer/index.js +90 -0
- package/dist/lib/signer/index.js.map +1 -0
- package/dist/lib/testDodoLive.d.ts +2 -0
- package/dist/lib/testDodoLive.d.ts.map +1 -0
- package/dist/lib/testDodoLive.js +105 -0
- package/dist/lib/testDodoLive.js.map +1 -0
- package/dist/lib/testLiveSafehands.d.ts +2 -0
- package/dist/lib/testLiveSafehands.d.ts.map +1 -0
- package/dist/lib/testLiveSafehands.js +93 -0
- package/dist/lib/testLiveSafehands.js.map +1 -0
- package/dist/lib/testRpcLive.d.ts +2 -0
- package/dist/lib/testRpcLive.d.ts.map +1 -0
- package/dist/lib/testRpcLive.js +89 -0
- package/dist/lib/testRpcLive.js.map +1 -0
- package/dist/lib/testTools.js +363 -354
- package/dist/lib/testTools.js.map +1 -1
- package/dist/lib/testX402Live.d.ts +2 -0
- package/dist/lib/testX402Live.d.ts.map +1 -0
- package/dist/lib/testX402Live.js +160 -0
- package/dist/lib/testX402Live.js.map +1 -0
- package/dist/lib/toolResponse.d.ts +26 -0
- package/dist/lib/toolResponse.d.ts.map +1 -0
- package/dist/lib/toolResponse.js +54 -0
- package/dist/lib/toolResponse.js.map +1 -0
- package/dist/lib/wallet/index.d.ts +19 -0
- package/dist/lib/wallet/index.d.ts.map +1 -0
- package/dist/lib/wallet/index.js +71 -0
- package/dist/lib/wallet/index.js.map +1 -0
- package/dist/tools/approveToken.d.ts +19 -20
- package/dist/tools/approveToken.d.ts.map +1 -1
- package/dist/tools/approveToken.js +44 -21
- package/dist/tools/approveToken.js.map +1 -1
- package/dist/tools/assessRisk.d.ts +22 -9
- package/dist/tools/assessRisk.d.ts.map +1 -1
- package/dist/tools/assessRisk.js +32 -9
- package/dist/tools/assessRisk.js.map +1 -1
- package/dist/tools/checkAllowance.d.ts +6 -6
- package/dist/tools/checkTokenSecurity.d.ts +9 -16
- package/dist/tools/checkTokenSecurity.d.ts.map +1 -1
- package/dist/tools/checkTokenSecurity.js +17 -22
- package/dist/tools/checkTokenSecurity.js.map +1 -1
- package/dist/tools/createAgentWallet.d.ts +27 -0
- package/dist/tools/createAgentWallet.d.ts.map +1 -0
- package/dist/tools/createAgentWallet.js +60 -0
- package/dist/tools/createAgentWallet.js.map +1 -0
- package/dist/tools/estimateGas.d.ts +31 -21
- package/dist/tools/estimateGas.d.ts.map +1 -1
- package/dist/tools/estimateGas.js +91 -95
- package/dist/tools/estimateGas.js.map +1 -1
- package/dist/tools/executeSwap.d.ts +13 -29
- package/dist/tools/executeSwap.d.ts.map +1 -1
- package/dist/tools/executeSwap.js +68 -46
- package/dist/tools/executeSwap.js.map +1 -1
- package/dist/tools/explainRisk.d.ts +30 -0
- package/dist/tools/explainRisk.d.ts.map +1 -0
- package/dist/tools/explainRisk.js +33 -0
- package/dist/tools/explainRisk.js.map +1 -0
- package/dist/tools/getAgentWallet.d.ts +22 -0
- package/dist/tools/getAgentWallet.d.ts.map +1 -0
- package/dist/tools/getAgentWallet.js +28 -0
- package/dist/tools/getAgentWallet.js.map +1 -0
- package/dist/tools/getAgentWalletBalance.d.ts +12 -0
- package/dist/tools/getAgentWalletBalance.d.ts.map +1 -0
- package/dist/tools/getAgentWalletBalance.js +71 -0
- package/dist/tools/getAgentWalletBalance.js.map +1 -0
- package/dist/tools/getExecutionHistory.d.ts +4 -4
- package/dist/tools/getGasPrice.d.ts +26 -8
- package/dist/tools/getGasPrice.d.ts.map +1 -1
- package/dist/tools/getGasPrice.js +43 -35
- package/dist/tools/getGasPrice.js.map +1 -1
- package/dist/tools/getPoolInfo.d.ts +47 -59
- package/dist/tools/getPoolInfo.d.ts.map +1 -1
- package/dist/tools/getPoolInfo.js +96 -57
- package/dist/tools/getPoolInfo.js.map +1 -1
- package/dist/tools/getTokenPrice.d.ts +95 -9
- package/dist/tools/getTokenPrice.d.ts.map +1 -1
- package/dist/tools/getTokenPrice.js +95 -56
- package/dist/tools/getTokenPrice.js.map +1 -1
- package/dist/tools/getWalletBalance.d.ts +40 -11
- package/dist/tools/getWalletBalance.d.ts.map +1 -1
- package/dist/tools/getWalletBalance.js +64 -47
- package/dist/tools/getWalletBalance.js.map +1 -1
- package/dist/tools/publishRiskScore.d.ts +12 -10
- package/dist/tools/publishRiskScore.d.ts.map +1 -1
- package/dist/tools/publishRiskScore.js +33 -19
- package/dist/tools/publishRiskScore.js.map +1 -1
- package/dist/tools/queryRiskRegistry.d.ts +3 -3
- package/dist/tools/safehandsPreflightCheck.d.ts +78 -0
- package/dist/tools/safehandsPreflightCheck.d.ts.map +1 -0
- package/dist/tools/safehandsPreflightCheck.js +48 -0
- package/dist/tools/safehandsPreflightCheck.js.map +1 -0
- package/dist/tools/safehandsRiskReport.d.ts +82 -0
- package/dist/tools/safehandsRiskReport.d.ts.map +1 -0
- package/dist/tools/safehandsRiskReport.js +29 -0
- package/dist/tools/safehandsRiskReport.js.map +1 -0
- package/dist/tools/safehandsSafeExecute.d.ts +21 -0
- package/dist/tools/safehandsSafeExecute.d.ts.map +1 -0
- package/dist/tools/safehandsSafeExecute.js +76 -0
- package/dist/tools/safehandsSafeExecute.js.map +1 -0
- package/dist/tools/safehandsWalletHealth.d.ts +15 -0
- package/dist/tools/safehandsWalletHealth.d.ts.map +1 -0
- package/dist/tools/safehandsWalletHealth.js +104 -0
- package/dist/tools/safehandsWalletHealth.js.map +1 -0
- package/dist/tools/safehandsX402Preflight.d.ts +27 -0
- package/dist/tools/safehandsX402Preflight.d.ts.map +1 -0
- package/dist/tools/safehandsX402Preflight.js +66 -0
- package/dist/tools/safehandsX402Preflight.js.map +1 -0
- package/dist/tools/sendPayment.d.ts +13 -35
- package/dist/tools/sendPayment.d.ts.map +1 -1
- package/dist/tools/sendPayment.js +53 -47
- package/dist/tools/sendPayment.js.map +1 -1
- package/dist/tools/simulateTransaction.d.ts +4 -4
- package/dist/tools/tokenRegistryStatus.d.ts +27 -0
- package/dist/tools/tokenRegistryStatus.d.ts.map +1 -0
- package/dist/tools/tokenRegistryStatus.js +97 -0
- package/dist/tools/tokenRegistryStatus.js.map +1 -0
- package/dist/tools/x402PayAndFetch.d.ts +40 -16
- package/dist/tools/x402PayAndFetch.d.ts.map +1 -1
- package/dist/tools/x402PayAndFetch.js +115 -47
- package/dist/tools/x402PayAndFetch.js.map +1 -1
- package/dist/x402Server.js +149 -115
- package/dist/x402Server.js.map +1 -1
- package/examples/pharos-skill-engine/SKILL.safehands.md +85 -0
- package/examples/pharos-skill-engine/assets/safehands/example-actions.json +49 -0
- package/examples/pharos-skill-engine/assets/safehands/policy-defaults.json +11 -0
- package/examples/pharos-skill-engine/references/safehands.md +345 -0
- package/examples/scenario-hack.ts +38 -0
- package/package.json +19 -5
- package/skill/SKILL.md +127 -0
- package/skill/assets/safehands/example-actions.json +49 -0
- package/skill/assets/safehands/policy-defaults.json +11 -0
- package/skill/references/safehands.md +345 -0
- package/.agents/skill/safehands/SKILL.md +0 -200
- package/.agents/skill/safehands/assets/networks.json +0 -24
- package/.agents/skill/safehands/assets/tokens.json +0 -60
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { z } from "zod";
|
|
2
|
+
import { type ToolResponse } from "../lib/toolResponse.js";
|
|
3
|
+
export declare const explainRiskSchema: z.ZodObject<{
|
|
4
|
+
decision: z.ZodEnum<["ALLOW", "WARN", "BLOCK", "REQUIRE_CONFIRMATION", "REQUIRE_FUNDING", "REQUIRE_TOKEN_REVIEW"]>;
|
|
5
|
+
riskLevel: z.ZodEnum<["LOW", "MEDIUM", "HIGH", "CRITICAL", "UNKNOWN"]>;
|
|
6
|
+
reasons: z.ZodDefault<z.ZodOptional<z.ZodArray<z.ZodString, "many">>>;
|
|
7
|
+
requiredActions: z.ZodDefault<z.ZodOptional<z.ZodArray<z.ZodString, "many">>>;
|
|
8
|
+
environment: z.ZodDefault<z.ZodOptional<z.ZodString>>;
|
|
9
|
+
chainId: z.ZodDefault<z.ZodOptional<z.ZodNumber>>;
|
|
10
|
+
isMainnet: z.ZodDefault<z.ZodOptional<z.ZodBoolean>>;
|
|
11
|
+
}, "strip", z.ZodTypeAny, {
|
|
12
|
+
riskLevel: "LOW" | "MEDIUM" | "HIGH" | "CRITICAL" | "UNKNOWN";
|
|
13
|
+
environment: string;
|
|
14
|
+
chainId: number;
|
|
15
|
+
isMainnet: boolean;
|
|
16
|
+
decision: "ALLOW" | "WARN" | "BLOCK" | "REQUIRE_CONFIRMATION" | "REQUIRE_FUNDING" | "REQUIRE_TOKEN_REVIEW";
|
|
17
|
+
reasons: string[];
|
|
18
|
+
requiredActions: string[];
|
|
19
|
+
}, {
|
|
20
|
+
riskLevel: "LOW" | "MEDIUM" | "HIGH" | "CRITICAL" | "UNKNOWN";
|
|
21
|
+
decision: "ALLOW" | "WARN" | "BLOCK" | "REQUIRE_CONFIRMATION" | "REQUIRE_FUNDING" | "REQUIRE_TOKEN_REVIEW";
|
|
22
|
+
environment?: string | undefined;
|
|
23
|
+
chainId?: number | undefined;
|
|
24
|
+
isMainnet?: boolean | undefined;
|
|
25
|
+
reasons?: string[] | undefined;
|
|
26
|
+
requiredActions?: string[] | undefined;
|
|
27
|
+
}>;
|
|
28
|
+
export type ExplainRiskInput = z.input<typeof explainRiskSchema>;
|
|
29
|
+
export declare function handleExplainRisk(raw: ExplainRiskInput): Promise<ToolResponse<unknown>>;
|
|
30
|
+
//# sourceMappingURL=explainRisk.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"explainRisk.d.ts","sourceRoot":"","sources":["../../src/tools/explainRisk.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AACxB,OAAO,EAAM,KAAK,YAAY,EAAE,MAAM,wBAAwB,CAAC;AAG/D,eAAO,MAAM,iBAAiB;;;;;;;;;;;;;;;;;;;;;;;;EAQ5B,CAAC;AAEH,MAAM,MAAM,gBAAgB,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,iBAAiB,CAAC,CAAC;AAEjE,wBAAsB,iBAAiB,CAAC,GAAG,EAAE,gBAAgB,GAAG,OAAO,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC,CAkB7F"}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
// ─── Tool: explain_risk ────────────────────────────────────────────────
|
|
2
|
+
import { z } from "zod";
|
|
3
|
+
import { ok } from "../lib/toolResponse.js";
|
|
4
|
+
import { explainPolicyResult } from "../lib/policy/actionPolicyEngine.js";
|
|
5
|
+
export const explainRiskSchema = z.object({
|
|
6
|
+
decision: z.enum(["ALLOW", "WARN", "BLOCK", "REQUIRE_CONFIRMATION", "REQUIRE_FUNDING", "REQUIRE_TOKEN_REVIEW"]),
|
|
7
|
+
riskLevel: z.enum(["LOW", "MEDIUM", "HIGH", "CRITICAL", "UNKNOWN"]),
|
|
8
|
+
reasons: z.array(z.string()).optional().default([]),
|
|
9
|
+
requiredActions: z.array(z.string()).optional().default([]),
|
|
10
|
+
environment: z.string().optional().default("atlantic-testnet"),
|
|
11
|
+
chainId: z.number().optional().default(688689),
|
|
12
|
+
isMainnet: z.boolean().optional().default(false),
|
|
13
|
+
});
|
|
14
|
+
export async function handleExplainRisk(raw) {
|
|
15
|
+
const input = explainRiskSchema.parse(raw);
|
|
16
|
+
const result = {
|
|
17
|
+
decision: input.decision,
|
|
18
|
+
riskLevel: input.riskLevel,
|
|
19
|
+
safeToExecute: input.decision === "ALLOW",
|
|
20
|
+
reasons: input.reasons,
|
|
21
|
+
requiredActions: input.requiredActions,
|
|
22
|
+
checks: [],
|
|
23
|
+
environment: input.environment,
|
|
24
|
+
chainId: input.chainId,
|
|
25
|
+
isMainnet: input.isMainnet,
|
|
26
|
+
};
|
|
27
|
+
return ok({
|
|
28
|
+
explanation: explainPolicyResult(result),
|
|
29
|
+
...result,
|
|
30
|
+
source: "explain_risk",
|
|
31
|
+
});
|
|
32
|
+
}
|
|
33
|
+
//# sourceMappingURL=explainRisk.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"explainRisk.js","sourceRoot":"","sources":["../../src/tools/explainRisk.ts"],"names":[],"mappings":"AAAA,0EAA0E;AAE1E,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AACxB,OAAO,EAAE,EAAE,EAAqB,MAAM,wBAAwB,CAAC;AAC/D,OAAO,EAAE,mBAAmB,EAA6C,MAAM,qCAAqC,CAAC;AAErH,MAAM,CAAC,MAAM,iBAAiB,GAAG,CAAC,CAAC,MAAM,CAAC;IACxC,QAAQ,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,sBAAsB,EAAE,iBAAiB,EAAE,sBAAsB,CAAC,CAAC;IAC/G,SAAS,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,KAAK,EAAE,QAAQ,EAAE,MAAM,EAAE,UAAU,EAAE,SAAS,CAAC,CAAC;IACnE,OAAO,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC,QAAQ,EAAE,CAAC,OAAO,CAAC,EAAE,CAAC;IACnD,eAAe,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC,QAAQ,EAAE,CAAC,OAAO,CAAC,EAAE,CAAC;IAC3D,WAAW,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE,CAAC,OAAO,CAAC,kBAAkB,CAAC;IAC9D,OAAO,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC;IAC9C,SAAS,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC,QAAQ,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC;CACjD,CAAC,CAAC;AAIH,MAAM,CAAC,KAAK,UAAU,iBAAiB,CAAC,GAAqB;IAC3D,MAAM,KAAK,GAAG,iBAAiB,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;IAC3C,MAAM,MAAM,GAAG;QACb,QAAQ,EAAE,KAAK,CAAC,QAA0B;QAC1C,SAAS,EAAE,KAAK,CAAC,SAA4B;QAC7C,aAAa,EAAE,KAAK,CAAC,QAAQ,KAAK,OAAO;QACzC,OAAO,EAAE,KAAK,CAAC,OAAO;QACtB,eAAe,EAAE,KAAK,CAAC,eAAe;QACtC,MAAM,EAAE,EAAE;QACV,WAAW,EAAE,KAAK,CAAC,WAAW;QAC9B,OAAO,EAAE,KAAK,CAAC,OAAO;QACtB,SAAS,EAAE,KAAK,CAAC,SAAS;KAC3B,CAAC;IACF,OAAO,EAAE,CAAC;QACR,WAAW,EAAE,mBAAmB,CAAC,MAAM,CAAC;QACxC,GAAG,MAAM;QACT,MAAM,EAAE,cAAc;KACvB,CAAC,CAAC;AACL,CAAC"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { z } from "zod";
|
|
2
|
+
import { type ToolResponse } from "../lib/toolResponse.js";
|
|
3
|
+
export declare const getAgentWalletSchema: z.ZodObject<{
|
|
4
|
+
agentId: z.ZodString;
|
|
5
|
+
}, "strip", z.ZodTypeAny, {
|
|
6
|
+
agentId: string;
|
|
7
|
+
}, {
|
|
8
|
+
agentId: string;
|
|
9
|
+
}>;
|
|
10
|
+
export type GetAgentWalletParams = z.infer<typeof getAgentWalletSchema>;
|
|
11
|
+
interface GetAgentWalletData {
|
|
12
|
+
agentId: string;
|
|
13
|
+
address: string;
|
|
14
|
+
environment: string;
|
|
15
|
+
chainId: number;
|
|
16
|
+
isMainnet: boolean;
|
|
17
|
+
createdAt: string;
|
|
18
|
+
explorerUrl: string;
|
|
19
|
+
}
|
|
20
|
+
export declare function handleGetAgentWallet(params: GetAgentWalletParams): Promise<ToolResponse<GetAgentWalletData>>;
|
|
21
|
+
export {};
|
|
22
|
+
//# sourceMappingURL=getAgentWallet.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"getAgentWallet.d.ts","sourceRoot":"","sources":["../../src/tools/getAgentWallet.ts"],"names":[],"mappings":"AAKA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AACxB,OAAO,EAAY,KAAK,YAAY,EAAE,MAAM,wBAAwB,CAAC;AAGrE,eAAO,MAAM,oBAAoB;;;;;;EAE/B,CAAC;AAEH,MAAM,MAAM,oBAAoB,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,oBAAoB,CAAC,CAAC;AAExE,UAAU,kBAAkB;IAC1B,OAAO,EAAE,MAAM,CAAC;IAChB,OAAO,EAAE,MAAM,CAAC;IAChB,WAAW,EAAE,MAAM,CAAC;IACpB,OAAO,EAAE,MAAM,CAAC;IAChB,SAAS,EAAE,OAAO,CAAC;IACnB,SAAS,EAAE,MAAM,CAAC;IAClB,WAAW,EAAE,MAAM,CAAC;CACrB;AAED,wBAAsB,oBAAoB,CACxC,MAAM,EAAE,oBAAoB,GAC3B,OAAO,CAAC,YAAY,CAAC,kBAAkB,CAAC,CAAC,CAwB3C"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
// ─── get_agent_wallet ───────────────────────────────────────────────────
|
|
2
|
+
// Returns public info for a managed agent wallet.
|
|
3
|
+
// Never returns private key.
|
|
4
|
+
// ────────────────────────────────────────────────────────────────────────
|
|
5
|
+
import { z } from "zod";
|
|
6
|
+
import { ok, fail } from "../lib/toolResponse.js";
|
|
7
|
+
import { walletStore } from "../lib/wallet/index.js";
|
|
8
|
+
export const getAgentWalletSchema = z.object({
|
|
9
|
+
agentId: z.string().min(1).max(64).describe("Agent wallet identifier"),
|
|
10
|
+
});
|
|
11
|
+
export async function handleGetAgentWallet(params) {
|
|
12
|
+
const { agentId } = params;
|
|
13
|
+
const wallet = await walletStore.get(agentId);
|
|
14
|
+
if (!wallet) {
|
|
15
|
+
return fail("WALLET_NOT_FOUND", `No wallet found for agentId '${agentId}'. Use create_agent_wallet to create one.`, false, "wallet_store");
|
|
16
|
+
}
|
|
17
|
+
const explorerBase = process.env.PHAROS_EXPLORER_BASE || "https://atlantic.pharosscan.xyz/address/";
|
|
18
|
+
return ok({
|
|
19
|
+
agentId: wallet.agentId,
|
|
20
|
+
address: wallet.address,
|
|
21
|
+
environment: wallet.environment,
|
|
22
|
+
chainId: wallet.chainId,
|
|
23
|
+
isMainnet: wallet.isMainnet,
|
|
24
|
+
createdAt: wallet.createdAt,
|
|
25
|
+
explorerUrl: `${explorerBase}${wallet.address}`,
|
|
26
|
+
});
|
|
27
|
+
}
|
|
28
|
+
//# sourceMappingURL=getAgentWallet.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"getAgentWallet.js","sourceRoot":"","sources":["../../src/tools/getAgentWallet.ts"],"names":[],"mappings":"AAAA,2EAA2E;AAC3E,kDAAkD;AAClD,6BAA6B;AAC7B,2EAA2E;AAE3E,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AACxB,OAAO,EAAE,EAAE,EAAE,IAAI,EAAqB,MAAM,wBAAwB,CAAC;AACrE,OAAO,EAAE,WAAW,EAAE,MAAM,wBAAwB,CAAC;AAErD,MAAM,CAAC,MAAM,oBAAoB,GAAG,CAAC,CAAC,MAAM,CAAC;IAC3C,OAAO,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,QAAQ,CAAC,yBAAyB,CAAC;CACvE,CAAC,CAAC;AAcH,MAAM,CAAC,KAAK,UAAU,oBAAoB,CACxC,MAA4B;IAE5B,MAAM,EAAE,OAAO,EAAE,GAAG,MAAM,CAAC;IAE3B,MAAM,MAAM,GAAG,MAAM,WAAW,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;IAC9C,IAAI,CAAC,MAAM,EAAE,CAAC;QACZ,OAAO,IAAI,CACT,kBAAkB,EAClB,gCAAgC,OAAO,2CAA2C,EAClF,KAAK,EACL,cAAc,CACf,CAAC;IACJ,CAAC;IAED,MAAM,YAAY,GAAG,OAAO,CAAC,GAAG,CAAC,oBAAoB,IAAI,0CAA0C,CAAC;IAEpG,OAAO,EAAE,CAAC;QACR,OAAO,EAAE,MAAM,CAAC,OAAO;QACvB,OAAO,EAAE,MAAM,CAAC,OAAO;QACvB,WAAW,EAAE,MAAM,CAAC,WAAW;QAC/B,OAAO,EAAE,MAAM,CAAC,OAAO;QACvB,SAAS,EAAE,MAAM,CAAC,SAAS;QAC3B,SAAS,EAAE,MAAM,CAAC,SAAS;QAC3B,WAAW,EAAE,GAAG,YAAY,GAAG,MAAM,CAAC,OAAO,EAAE;KAChD,CAAC,CAAC;AACL,CAAC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { z } from "zod";
|
|
2
|
+
import { type ToolResponse } from "../lib/toolResponse.js";
|
|
3
|
+
export declare const getAgentWalletBalanceSchema: z.ZodObject<{
|
|
4
|
+
agentId: z.ZodString;
|
|
5
|
+
}, "strip", z.ZodTypeAny, {
|
|
6
|
+
agentId: string;
|
|
7
|
+
}, {
|
|
8
|
+
agentId: string;
|
|
9
|
+
}>;
|
|
10
|
+
export type GetAgentWalletBalanceParams = z.infer<typeof getAgentWalletBalanceSchema>;
|
|
11
|
+
export declare function handleGetAgentWalletBalance(params: GetAgentWalletBalanceParams): Promise<ToolResponse<unknown>>;
|
|
12
|
+
//# sourceMappingURL=getAgentWalletBalance.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"getAgentWalletBalance.d.ts","sourceRoot":"","sources":["../../src/tools/getAgentWalletBalance.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AACxB,OAAO,EAAmC,KAAK,YAAY,EAAE,MAAM,wBAAwB,CAAC;AAM5F,eAAO,MAAM,2BAA2B;;;;;;EAEtC,CAAC;AAEH,MAAM,MAAM,2BAA2B,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,2BAA2B,CAAC,CAAC;AAYtF,wBAAsB,2BAA2B,CAC/C,MAAM,EAAE,2BAA2B,GAClC,OAAO,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC,CAyDhC"}
|
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
// ─── get_agent_wallet_balance ───────────────────────────────────────────
|
|
2
|
+
// Returns PHRS + token balances for a managed agent wallet.
|
|
3
|
+
// ────────────────────────────────────────────────────────────────────────
|
|
4
|
+
import { z } from "zod";
|
|
5
|
+
import { ok, fail, classifyExternalError } from "../lib/toolResponse.js";
|
|
6
|
+
import { walletStore } from "../lib/wallet/index.js";
|
|
7
|
+
import { publicClient } from "../lib/pharosClient.js";
|
|
8
|
+
import { TOKEN_REGISTRY } from "../lib/constants.js";
|
|
9
|
+
import { formatUnits } from "viem";
|
|
10
|
+
export const getAgentWalletBalanceSchema = z.object({
|
|
11
|
+
agentId: z.string().min(1).max(64).describe("Agent wallet identifier"),
|
|
12
|
+
});
|
|
13
|
+
const ERC20_ABI = [
|
|
14
|
+
{
|
|
15
|
+
name: "balanceOf",
|
|
16
|
+
type: "function",
|
|
17
|
+
stateMutability: "view",
|
|
18
|
+
inputs: [{ name: "account", type: "address" }],
|
|
19
|
+
outputs: [{ name: "", type: "uint256" }],
|
|
20
|
+
},
|
|
21
|
+
];
|
|
22
|
+
export async function handleGetAgentWalletBalance(params) {
|
|
23
|
+
const { agentId } = params;
|
|
24
|
+
const wallet = await walletStore.get(agentId);
|
|
25
|
+
if (!wallet) {
|
|
26
|
+
return fail("WALLET_NOT_FOUND", `No wallet found for agentId '${agentId}'. Use create_agent_wallet to create one.`, false, "wallet_store");
|
|
27
|
+
}
|
|
28
|
+
const address = wallet.address;
|
|
29
|
+
try {
|
|
30
|
+
const [phrsRaw, usdcRaw, usdtRaw] = await Promise.all([
|
|
31
|
+
publicClient.getBalance({ address }),
|
|
32
|
+
publicClient.readContract({
|
|
33
|
+
address: TOKEN_REGISTRY.USDC.address,
|
|
34
|
+
abi: ERC20_ABI,
|
|
35
|
+
functionName: "balanceOf",
|
|
36
|
+
args: [address],
|
|
37
|
+
}),
|
|
38
|
+
publicClient.readContract({
|
|
39
|
+
address: TOKEN_REGISTRY.USDT.address,
|
|
40
|
+
abi: ERC20_ABI,
|
|
41
|
+
functionName: "balanceOf",
|
|
42
|
+
args: [address],
|
|
43
|
+
}),
|
|
44
|
+
]);
|
|
45
|
+
const phrs = formatUnits(phrsRaw, 18);
|
|
46
|
+
const usdc = formatUnits(usdcRaw, 6);
|
|
47
|
+
const usdt = formatUnits(usdtRaw, 6);
|
|
48
|
+
const isFunded = parseFloat(phrs) > 0;
|
|
49
|
+
return ok({
|
|
50
|
+
agentId,
|
|
51
|
+
address,
|
|
52
|
+
environment: wallet.environment,
|
|
53
|
+
chainId: wallet.chainId,
|
|
54
|
+
isMainnet: false,
|
|
55
|
+
explorerUrl: `https://atlantic.pharosscan.xyz/address/${address}`,
|
|
56
|
+
balances: {
|
|
57
|
+
PHRS: { value: phrs, unit: "PHRS", decimals: 18 },
|
|
58
|
+
USDC: { value: usdc, unit: "USDC", decimals: 6 },
|
|
59
|
+
USDT: { value: usdt, unit: "USDT", decimals: 6 },
|
|
60
|
+
},
|
|
61
|
+
isFunded,
|
|
62
|
+
fundingInstructions: isFunded
|
|
63
|
+
? null
|
|
64
|
+
: `Wallet is unfunded. Get testnet PHRS from https://testnet.pharosnetwork.xyz/ — wallet address: ${address}`,
|
|
65
|
+
});
|
|
66
|
+
}
|
|
67
|
+
catch (err) {
|
|
68
|
+
return classifyExternalError("pharos_rpc", err);
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
//# sourceMappingURL=getAgentWalletBalance.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"getAgentWalletBalance.js","sourceRoot":"","sources":["../../src/tools/getAgentWalletBalance.ts"],"names":[],"mappings":"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"}
|
|
@@ -4,12 +4,12 @@ export declare const getExecutionHistorySchema: z.ZodObject<{
|
|
|
4
4
|
limit: z.ZodDefault<z.ZodOptional<z.ZodNumber>>;
|
|
5
5
|
filter: z.ZodDefault<z.ZodOptional<z.ZodEnum<["swap", "transfer", "all"]>>>;
|
|
6
6
|
}, "strip", z.ZodTypeAny, {
|
|
7
|
-
filter: "transfer" | "
|
|
7
|
+
filter: "transfer" | "all" | "swap";
|
|
8
8
|
walletAddress: string;
|
|
9
9
|
limit: number;
|
|
10
10
|
}, {
|
|
11
11
|
walletAddress: string;
|
|
12
|
-
filter?: "transfer" | "
|
|
12
|
+
filter?: "transfer" | "all" | "swap" | undefined;
|
|
13
13
|
limit?: number | undefined;
|
|
14
14
|
}>;
|
|
15
15
|
export type GetExecutionHistoryInput = z.infer<typeof getExecutionHistorySchema>;
|
|
@@ -21,12 +21,12 @@ export declare const getExecutionHistoryTool: {
|
|
|
21
21
|
limit: z.ZodDefault<z.ZodOptional<z.ZodNumber>>;
|
|
22
22
|
filter: z.ZodDefault<z.ZodOptional<z.ZodEnum<["swap", "transfer", "all"]>>>;
|
|
23
23
|
}, "strip", z.ZodTypeAny, {
|
|
24
|
-
filter: "transfer" | "
|
|
24
|
+
filter: "transfer" | "all" | "swap";
|
|
25
25
|
walletAddress: string;
|
|
26
26
|
limit: number;
|
|
27
27
|
}, {
|
|
28
28
|
walletAddress: string;
|
|
29
|
-
filter?: "transfer" | "
|
|
29
|
+
filter?: "transfer" | "all" | "swap" | undefined;
|
|
30
30
|
limit?: number | undefined;
|
|
31
31
|
}>;
|
|
32
32
|
};
|
|
@@ -6,21 +6,39 @@ export declare const getGasPriceTool: {
|
|
|
6
6
|
description: string;
|
|
7
7
|
inputSchema: z.ZodObject<{}, "strip", z.ZodTypeAny, {}, {}>;
|
|
8
8
|
};
|
|
9
|
-
export declare function handleGetGasPrice(_raw: GetGasPriceInput): Promise<{
|
|
10
|
-
|
|
9
|
+
export declare function handleGetGasPrice(_raw: GetGasPriceInput): Promise<import("../lib/toolResponse.js").ToolFailure | import("../lib/toolResponse.js").ToolSuccess<{
|
|
10
|
+
gasPrice: {
|
|
11
|
+
value: string;
|
|
12
|
+
unit: string;
|
|
13
|
+
};
|
|
11
14
|
gasPriceWei: string;
|
|
12
15
|
trend: "low" | "high" | "normal";
|
|
13
16
|
recommendation: string;
|
|
14
17
|
estimates: {
|
|
15
18
|
nativeTransfer: {
|
|
16
|
-
gas:
|
|
17
|
-
|
|
19
|
+
gas: {
|
|
20
|
+
value: string;
|
|
21
|
+
unit: string;
|
|
22
|
+
};
|
|
23
|
+
costPHRS: {
|
|
24
|
+
value: string;
|
|
25
|
+
unit: string;
|
|
26
|
+
};
|
|
18
27
|
};
|
|
19
28
|
tokenSwap: {
|
|
20
|
-
gas:
|
|
21
|
-
|
|
29
|
+
gas: {
|
|
30
|
+
value: string;
|
|
31
|
+
unit: string;
|
|
32
|
+
};
|
|
33
|
+
costPHRS: {
|
|
34
|
+
value: string;
|
|
35
|
+
unit: string;
|
|
36
|
+
};
|
|
22
37
|
};
|
|
23
38
|
};
|
|
24
|
-
|
|
25
|
-
|
|
39
|
+
chainId: number;
|
|
40
|
+
environment: string;
|
|
41
|
+
isMainnet: boolean;
|
|
42
|
+
source: string;
|
|
43
|
+
}>>;
|
|
26
44
|
//# sourceMappingURL=getGasPrice.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"getGasPrice.d.ts","sourceRoot":"","sources":["../../src/tools/getGasPrice.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;
|
|
1
|
+
{"version":3,"file":"getGasPrice.d.ts","sourceRoot":"","sources":["../../src/tools/getGasPrice.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAMxB,eAAO,MAAM,iBAAiB,gDAAe,CAAC;AAE9C,MAAM,MAAM,gBAAgB,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,iBAAiB,CAAC,CAAC;AAEjE,eAAO,MAAM,eAAe;;;;CAK3B,CAAC;AAEF,wBAAsB,iBAAiB,CAAC,IAAI,EAAE,gBAAgB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;IA6C7D"}
|
|
@@ -4,6 +4,8 @@
|
|
|
4
4
|
import { z } from "zod";
|
|
5
5
|
import { publicClient } from "../lib/pharosClient.js";
|
|
6
6
|
import { formatGwei } from "viem";
|
|
7
|
+
import { CHAIN_ID, PHAROS_ENVIRONMENT } from "../lib/constants.js";
|
|
8
|
+
import { classifyExternalError, ok } from "../lib/toolResponse.js";
|
|
7
9
|
export const getGasPriceSchema = z.object({});
|
|
8
10
|
export const getGasPriceTool = {
|
|
9
11
|
name: "get_gas_price",
|
|
@@ -11,42 +13,48 @@ export const getGasPriceTool = {
|
|
|
11
13
|
inputSchema: getGasPriceSchema,
|
|
12
14
|
};
|
|
13
15
|
export async function handleGetGasPrice(_raw) {
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
16
|
+
try {
|
|
17
|
+
const gasPrice = await publicClient.getGasPrice();
|
|
18
|
+
const gasPriceGwei = parseFloat(formatGwei(gasPrice));
|
|
19
|
+
let trend;
|
|
20
|
+
let recommendation;
|
|
21
|
+
if (gasPriceGwei <= 5) {
|
|
22
|
+
trend = "low";
|
|
23
|
+
recommendation = "Gas is cheap. Good time to execute testnet transactions.";
|
|
24
|
+
}
|
|
25
|
+
else if (gasPriceGwei <= 50) {
|
|
26
|
+
trend = "normal";
|
|
27
|
+
recommendation = "Gas is at normal testnet levels. Proceed with standard transactions.";
|
|
28
|
+
}
|
|
29
|
+
else {
|
|
30
|
+
trend = "high";
|
|
31
|
+
recommendation = "Gas is elevated. Consider waiting or reducing transaction complexity.";
|
|
32
|
+
}
|
|
33
|
+
const transferCostWei = gasPrice * 21000n;
|
|
34
|
+
const swapCostWei = gasPrice * 250000n;
|
|
35
|
+
return ok({
|
|
36
|
+
gasPrice: { value: gasPriceGwei.toFixed(4), unit: "gwei" },
|
|
37
|
+
gasPriceWei: gasPrice.toString(),
|
|
38
|
+
trend,
|
|
39
|
+
recommendation,
|
|
40
|
+
estimates: {
|
|
41
|
+
nativeTransfer: {
|
|
42
|
+
gas: { value: "21000", unit: "gas" },
|
|
43
|
+
costPHRS: { value: (Number(transferCostWei) / 1e18).toFixed(8), unit: "PHRS" },
|
|
44
|
+
},
|
|
45
|
+
tokenSwap: {
|
|
46
|
+
gas: { value: "250000", unit: "gas" },
|
|
47
|
+
costPHRS: { value: (Number(swapCostWei) / 1e18).toFixed(8), unit: "PHRS" },
|
|
48
|
+
},
|
|
49
|
+
},
|
|
50
|
+
chainId: CHAIN_ID,
|
|
51
|
+
environment: PHAROS_ENVIRONMENT,
|
|
52
|
+
isMainnet: false,
|
|
53
|
+
source: "pharos_rpc",
|
|
54
|
+
});
|
|
26
55
|
}
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
recommendation = "Gas is elevated. Consider waiting or reducing transaction complexity.";
|
|
56
|
+
catch (err) {
|
|
57
|
+
return classifyExternalError("pharos_rpc", err);
|
|
30
58
|
}
|
|
31
|
-
// Estimate costs for common operations
|
|
32
|
-
const transferCostWei = gasPrice * 21000n;
|
|
33
|
-
const swapCostWei = gasPrice * 250000n; // typical swap gas
|
|
34
|
-
return {
|
|
35
|
-
gasPriceGwei: gasPriceGwei.toFixed(4),
|
|
36
|
-
gasPriceWei: gasPrice.toString(),
|
|
37
|
-
trend,
|
|
38
|
-
recommendation,
|
|
39
|
-
estimates: {
|
|
40
|
-
nativeTransfer: {
|
|
41
|
-
gas: "21,000",
|
|
42
|
-
costPHRS: (Number(transferCostWei) / 1e18).toFixed(8),
|
|
43
|
-
},
|
|
44
|
-
tokenSwap: {
|
|
45
|
-
gas: "~250,000",
|
|
46
|
-
costPHRS: (Number(swapCostWei) / 1e18).toFixed(8),
|
|
47
|
-
},
|
|
48
|
-
},
|
|
49
|
-
timestamp: new Date().toISOString(),
|
|
50
|
-
};
|
|
51
59
|
}
|
|
52
60
|
//# sourceMappingURL=getGasPrice.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"getGasPrice.js","sourceRoot":"","sources":["../../src/tools/getGasPrice.ts"],"names":[],"mappings":"AAAA,0EAA0E;AAC1E,iEAAiE;AACjE,2EAA2E;AAE3E,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AACxB,OAAO,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAC;AACtD,OAAO,EAAE,UAAU,EAAE,MAAM,MAAM,CAAC;
|
|
1
|
+
{"version":3,"file":"getGasPrice.js","sourceRoot":"","sources":["../../src/tools/getGasPrice.ts"],"names":[],"mappings":"AAAA,0EAA0E;AAC1E,iEAAiE;AACjE,2EAA2E;AAE3E,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AACxB,OAAO,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAC;AACtD,OAAO,EAAE,UAAU,EAAE,MAAM,MAAM,CAAC;AAClC,OAAO,EAAE,QAAQ,EAAE,kBAAkB,EAAE,MAAM,qBAAqB,CAAC;AACnE,OAAO,EAAE,qBAAqB,EAAE,EAAE,EAAE,MAAM,wBAAwB,CAAC;AAEnE,MAAM,CAAC,MAAM,iBAAiB,GAAG,CAAC,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;AAI9C,MAAM,CAAC,MAAM,eAAe,GAAG;IAC7B,IAAI,EAAE,eAAe;IACrB,WAAW,EACT,sHAAsH;IACxH,WAAW,EAAE,iBAAiB;CAC/B,CAAC;AAEF,MAAM,CAAC,KAAK,UAAU,iBAAiB,CAAC,IAAsB;IAC5D,IAAI,CAAC;QACH,MAAM,QAAQ,GAAG,MAAM,YAAY,CAAC,WAAW,EAAE,CAAC;QAClD,MAAM,YAAY,GAAG,UAAU,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC,CAAC;QAEtD,IAAI,KAAgC,CAAC;QACrC,IAAI,cAAsB,CAAC;QAE3B,IAAI,YAAY,IAAI,CAAC,EAAE,CAAC;YACtB,KAAK,GAAG,KAAK,CAAC;YACd,cAAc,GAAG,0DAA0D,CAAC;QAC9E,CAAC;aAAM,IAAI,YAAY,IAAI,EAAE,EAAE,CAAC;YAC9B,KAAK,GAAG,QAAQ,CAAC;YACjB,cAAc,GAAG,sEAAsE,CAAC;QAC1F,CAAC;aAAM,CAAC;YACN,KAAK,GAAG,MAAM,CAAC;YACf,cAAc,GAAG,uEAAuE,CAAC;QAC3F,CAAC;QAED,MAAM,eAAe,GAAG,QAAQ,GAAG,MAAM,CAAC;QAC1C,MAAM,WAAW,GAAG,QAAQ,GAAG,OAAO,CAAC;QAEvC,OAAO,EAAE,CAAC;YACR,QAAQ,EAAE,EAAE,KAAK,EAAE,YAAY,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE;YAC1D,WAAW,EAAE,QAAQ,CAAC,QAAQ,EAAE;YAChC,KAAK;YACL,cAAc;YACd,SAAS,EAAE;gBACT,cAAc,EAAE;oBACd,GAAG,EAAE,EAAE,KAAK,EAAE,OAAO,EAAE,IAAI,EAAE,KAAK,EAAE;oBACpC,QAAQ,EAAE,EAAE,KAAK,EAAE,CAAC,MAAM,CAAC,eAAe,CAAC,GAAG,IAAI,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE;iBAC/E;gBACD,SAAS,EAAE;oBACT,GAAG,EAAE,EAAE,KAAK,EAAE,QAAQ,EAAE,IAAI,EAAE,KAAK,EAAE;oBACrC,QAAQ,EAAE,EAAE,KAAK,EAAE,CAAC,MAAM,CAAC,WAAW,CAAC,GAAG,IAAI,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE;iBAC3E;aACF;YACD,OAAO,EAAE,QAAQ;YACjB,WAAW,EAAE,kBAAkB;YAC/B,SAAS,EAAE,KAAK;YAChB,MAAM,EAAE,YAAY;SACrB,CAAC,CAAC;IACL,CAAC;IAAC,OAAO,GAAG,EAAE,CAAC;QACb,OAAO,qBAAqB,CAAC,YAAY,EAAE,GAAG,CAAC,CAAC;IAClD,CAAC;AACH,CAAC"}
|
|
@@ -3,11 +3,11 @@ export declare const getPoolInfoSchema: z.ZodObject<{
|
|
|
3
3
|
tokenA: z.ZodEnum<["PHRS", "USDC", "USDT"]>;
|
|
4
4
|
tokenB: z.ZodEnum<["PHRS", "USDC", "USDT"]>;
|
|
5
5
|
}, "strip", z.ZodTypeAny, {
|
|
6
|
-
tokenA: "PHRS" | "
|
|
7
|
-
tokenB: "PHRS" | "
|
|
6
|
+
tokenA: "PHRS" | "USDC" | "USDT";
|
|
7
|
+
tokenB: "PHRS" | "USDC" | "USDT";
|
|
8
8
|
}, {
|
|
9
|
-
tokenA: "PHRS" | "
|
|
10
|
-
tokenB: "PHRS" | "
|
|
9
|
+
tokenA: "PHRS" | "USDC" | "USDT";
|
|
10
|
+
tokenB: "PHRS" | "USDC" | "USDT";
|
|
11
11
|
}>;
|
|
12
12
|
export type GetPoolInfoInput = z.input<typeof getPoolInfoSchema>;
|
|
13
13
|
export declare const getPoolInfoTool: {
|
|
@@ -17,72 +17,60 @@ export declare const getPoolInfoTool: {
|
|
|
17
17
|
tokenA: z.ZodEnum<["PHRS", "USDC", "USDT"]>;
|
|
18
18
|
tokenB: z.ZodEnum<["PHRS", "USDC", "USDT"]>;
|
|
19
19
|
}, "strip", z.ZodTypeAny, {
|
|
20
|
-
tokenA: "PHRS" | "
|
|
21
|
-
tokenB: "PHRS" | "
|
|
20
|
+
tokenA: "PHRS" | "USDC" | "USDT";
|
|
21
|
+
tokenB: "PHRS" | "USDC" | "USDT";
|
|
22
22
|
}, {
|
|
23
|
-
tokenA: "PHRS" | "
|
|
24
|
-
tokenB: "PHRS" | "
|
|
23
|
+
tokenA: "PHRS" | "USDC" | "USDT";
|
|
24
|
+
tokenB: "PHRS" | "USDC" | "USDT";
|
|
25
25
|
}>;
|
|
26
26
|
};
|
|
27
|
-
export declare function handleGetPoolInfo(raw: GetPoolInfoInput): Promise<{
|
|
28
|
-
pair: string;
|
|
29
|
-
error: string;
|
|
30
|
-
available?: undefined;
|
|
31
|
-
message?: undefined;
|
|
32
|
-
timestamp?: undefined;
|
|
33
|
-
priceRatio?: undefined;
|
|
34
|
-
priceImpact?: undefined;
|
|
35
|
-
pricePerFromToken?: undefined;
|
|
36
|
-
pricePerToToken?: undefined;
|
|
37
|
-
fee?: undefined;
|
|
38
|
-
liquidity?: undefined;
|
|
39
|
-
source?: undefined;
|
|
40
|
-
chainId?: undefined;
|
|
41
|
-
} | {
|
|
27
|
+
export declare function handleGetPoolInfo(raw: GetPoolInfoInput): Promise<import("../lib/toolResponse.js").ToolFailure | import("../lib/toolResponse.js").ToolSuccess<{
|
|
42
28
|
pair: string;
|
|
43
29
|
available: boolean;
|
|
44
30
|
message: string;
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
liquidity?: undefined;
|
|
53
|
-
source?: undefined;
|
|
54
|
-
chainId?: undefined;
|
|
55
|
-
} | {
|
|
31
|
+
source: string;
|
|
32
|
+
sourceStatus: string;
|
|
33
|
+
publicMode: boolean;
|
|
34
|
+
chainId: number;
|
|
35
|
+
environment: string;
|
|
36
|
+
isMainnet: boolean;
|
|
37
|
+
}> | import("../lib/toolResponse.js").ToolSuccess<{
|
|
56
38
|
pair: string;
|
|
57
39
|
available: boolean;
|
|
58
|
-
priceRatio:
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
40
|
+
priceRatio: {
|
|
41
|
+
value: string;
|
|
42
|
+
unit: "PHRS" | "USDC" | "USDT";
|
|
43
|
+
per: string;
|
|
44
|
+
} | null;
|
|
45
|
+
priceImpact: {
|
|
46
|
+
value: string;
|
|
47
|
+
unit: string;
|
|
48
|
+
};
|
|
49
|
+
pricePerFromToken: {
|
|
50
|
+
value: string;
|
|
51
|
+
unit: "PHRS" | "USDC" | "USDT";
|
|
52
|
+
} | null;
|
|
53
|
+
pricePerToToken: {
|
|
54
|
+
value: string;
|
|
55
|
+
unit: "PHRS" | "USDC" | "USDT";
|
|
56
|
+
} | null;
|
|
57
|
+
fee: {
|
|
58
|
+
value: string;
|
|
59
|
+
unit: string;
|
|
60
|
+
} | null;
|
|
61
|
+
liquidity: {
|
|
64
62
|
baseLiquidity: string;
|
|
65
63
|
quoteLiquidity: string;
|
|
66
64
|
poolType: string;
|
|
67
|
-
};
|
|
65
|
+
} | null;
|
|
66
|
+
poolListStatus: string;
|
|
68
67
|
source: string;
|
|
68
|
+
sourceStatus: string;
|
|
69
|
+
publicMode: boolean;
|
|
70
|
+
routeAvailable: boolean;
|
|
71
|
+
confidence: string;
|
|
69
72
|
chainId: number;
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
} | {
|
|
74
|
-
pair: string;
|
|
75
|
-
available: boolean;
|
|
76
|
-
error: string;
|
|
77
|
-
timestamp: string;
|
|
78
|
-
message?: undefined;
|
|
79
|
-
priceRatio?: undefined;
|
|
80
|
-
priceImpact?: undefined;
|
|
81
|
-
pricePerFromToken?: undefined;
|
|
82
|
-
pricePerToToken?: undefined;
|
|
83
|
-
fee?: undefined;
|
|
84
|
-
liquidity?: undefined;
|
|
85
|
-
source?: undefined;
|
|
86
|
-
chainId?: undefined;
|
|
87
|
-
}>;
|
|
73
|
+
environment: string;
|
|
74
|
+
isMainnet: boolean;
|
|
75
|
+
}>>;
|
|
88
76
|
//# sourceMappingURL=getPoolInfo.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"getPoolInfo.d.ts","sourceRoot":"","sources":["../../src/tools/getPoolInfo.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"getPoolInfo.d.ts","sourceRoot":"","sources":["../../src/tools/getPoolInfo.ts"],"names":[],"mappings":"AAMA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAMxB,eAAO,MAAM,iBAAiB;;;;;;;;;EAG5B,CAAC;AAEH,MAAM,MAAM,gBAAgB,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,iBAAiB,CAAC,CAAC;AAEjE,eAAO,MAAM,eAAe;;;;;;;;;;;;;CAK3B,CAAC;AA4BF,wBAAsB,iBAAiB,CAAC,GAAG,EAAE,gBAAgB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;uBA8ErB,MAAM;wBAAkB,MAAM;kBAAY,MAAM;;;;;;;;;;;IAwDvF"}
|