solforge 0.2.5 → 0.2.7
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 +1 -1
- package/scripts/postinstall.cjs +3 -3
- package/server/lib/base58.ts +1 -1
- package/server/lib/instruction-parser.ts +242 -0
- package/server/methods/account/get-account-info.ts +3 -7
- package/server/methods/account/get-balance.ts +3 -7
- package/server/methods/account/get-multiple-accounts.ts +2 -1
- package/server/methods/account/get-parsed-account-info.ts +3 -7
- package/server/methods/account/parsers/index.ts +2 -2
- package/server/methods/account/parsers/loader-upgradeable.ts +14 -1
- package/server/methods/account/parsers/spl-token.ts +29 -10
- package/server/methods/account/request-airdrop.ts +122 -86
- package/server/methods/admin/mint-to.ts +11 -38
- package/server/methods/block/get-block.ts +3 -7
- package/server/methods/block/get-blocks-with-limit.ts +3 -7
- package/server/methods/block/is-blockhash-valid.ts +3 -7
- package/server/methods/get-address-lookup-table.ts +3 -7
- package/server/methods/program/get-program-accounts.ts +9 -9
- package/server/methods/program/get-token-account-balance.ts +3 -7
- package/server/methods/program/get-token-accounts-by-delegate.ts +4 -3
- package/server/methods/program/get-token-accounts-by-owner.ts +54 -33
- package/server/methods/program/get-token-largest-accounts.ts +3 -2
- package/server/methods/program/get-token-supply.ts +3 -2
- package/server/methods/solforge/index.ts +9 -6
- package/server/methods/transaction/get-parsed-transaction.ts +3 -7
- package/server/methods/transaction/get-signature-statuses.ts +14 -7
- package/server/methods/transaction/get-signatures-for-address.ts +3 -7
- package/server/methods/transaction/get-transaction.ts +434 -287
- package/server/methods/transaction/inner-instructions.test.ts +63 -0
- package/server/methods/transaction/send-transaction.ts +248 -56
- package/server/methods/transaction/simulate-transaction.ts +3 -2
- package/server/rpc-server.ts +98 -61
- package/server/types.ts +65 -30
- package/server/ws-server.ts +11 -7
- package/src/api-server-entry.ts +5 -5
- package/src/cli/commands/airdrop.ts +2 -2
- package/src/cli/commands/config.ts +2 -2
- package/src/cli/commands/mint.ts +3 -3
- package/src/cli/commands/program-clone.ts +9 -11
- package/src/cli/commands/program-load.ts +3 -3
- package/src/cli/commands/rpc-start.ts +7 -7
- package/src/cli/commands/token-adopt-authority.ts +1 -1
- package/src/cli/commands/token-clone.ts +5 -6
- package/src/cli/commands/token-create.ts +5 -5
- package/src/cli/main.ts +33 -36
- package/src/cli/run-solforge.ts +3 -3
- package/src/cli/setup-wizard.ts +8 -6
- package/src/commands/add-program.ts +1 -1
- package/src/commands/init.ts +2 -2
- package/src/commands/mint.ts +5 -6
- package/src/commands/start.ts +10 -9
- package/src/commands/status.ts +1 -1
- package/src/commands/stop.ts +1 -1
- package/src/config/index.ts +33 -17
- package/src/config/manager.ts +3 -3
- package/src/db/index.ts +2 -2
- package/src/db/schema/index.ts +1 -0
- package/src/db/schema/transactions.ts +29 -22
- package/src/db/schema/tx-account-states.ts +21 -0
- package/src/db/tx-store.ts +113 -76
- package/src/gui/public/app.css +13 -13
- package/src/gui/server.ts +1 -1
- package/src/gui/src/api.ts +1 -1
- package/src/gui/src/app.tsx +49 -17
- package/src/gui/src/components/airdrop-mint-form.tsx +32 -8
- package/src/gui/src/components/clone-program-modal.tsx +25 -6
- package/src/gui/src/components/clone-token-modal.tsx +25 -6
- package/src/gui/src/components/modal.tsx +6 -1
- package/src/gui/src/components/status-panel.tsx +1 -1
- package/src/index.ts +19 -6
- package/src/migrations-bundled.ts +8 -2
- package/src/services/api-server.ts +41 -19
- package/src/services/port-manager.ts +7 -10
- package/src/services/process-registry.ts +4 -5
- package/src/services/program-cloner.ts +4 -4
- package/src/services/token-cloner.ts +4 -4
- package/src/services/validator.ts +2 -4
- package/src/types/config.ts +2 -2
- package/src/utils/shell.ts +1 -1
- package/src/utils/token-loader.ts +2 -2
|
@@ -46,12 +46,13 @@ export const solforgeGetStatus: RpcMethodHandler = async (
|
|
|
46
46
|
...formatLamports(faucetLamports),
|
|
47
47
|
},
|
|
48
48
|
});
|
|
49
|
-
} catch (error:
|
|
49
|
+
} catch (error: unknown) {
|
|
50
|
+
const message = error instanceof Error ? error.message : String(error);
|
|
50
51
|
return context.createErrorResponse(
|
|
51
52
|
id,
|
|
52
53
|
-32603,
|
|
53
54
|
"Status unavailable",
|
|
54
|
-
|
|
55
|
+
message,
|
|
55
56
|
);
|
|
56
57
|
}
|
|
57
58
|
};
|
|
@@ -90,12 +91,13 @@ export const solforgeListPrograms: RpcMethodHandler = async (
|
|
|
90
91
|
.filter(Boolean);
|
|
91
92
|
|
|
92
93
|
return context.createSuccessResponse(id, detailed);
|
|
93
|
-
} catch (error:
|
|
94
|
+
} catch (error: unknown) {
|
|
95
|
+
const message = error instanceof Error ? error.message : String(error);
|
|
94
96
|
return context.createErrorResponse(
|
|
95
97
|
id,
|
|
96
98
|
-32603,
|
|
97
99
|
"List programs failed",
|
|
98
|
-
|
|
100
|
+
message,
|
|
99
101
|
);
|
|
100
102
|
}
|
|
101
103
|
};
|
|
@@ -144,12 +146,13 @@ export const solforgeListTokensDetailed: RpcMethodHandler = async (
|
|
|
144
146
|
.filter(Boolean);
|
|
145
147
|
|
|
146
148
|
return context.createSuccessResponse(id, detailed);
|
|
147
|
-
} catch (error:
|
|
149
|
+
} catch (error: unknown) {
|
|
150
|
+
const message = error instanceof Error ? error.message : String(error);
|
|
148
151
|
return context.createErrorResponse(
|
|
149
152
|
id,
|
|
150
153
|
-32603,
|
|
151
154
|
"List tokens failed",
|
|
152
|
-
|
|
155
|
+
message,
|
|
153
156
|
);
|
|
154
157
|
}
|
|
155
158
|
};
|
|
@@ -10,12 +10,8 @@ export const getParsedTransaction: RpcMethodHandler = async (
|
|
|
10
10
|
const cfg = { ...(config || {}), encoding: "jsonParsed" };
|
|
11
11
|
try {
|
|
12
12
|
return await getTransaction(id, [signature, cfg], context);
|
|
13
|
-
} catch (error:
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
-32603,
|
|
17
|
-
"Internal error",
|
|
18
|
-
error.message,
|
|
19
|
-
);
|
|
13
|
+
} catch (error: unknown) {
|
|
14
|
+
const message = error instanceof Error ? error.message : String(error);
|
|
15
|
+
return context.createErrorResponse(id, -32603, "Internal error", message);
|
|
20
16
|
}
|
|
21
17
|
};
|
|
@@ -7,7 +7,7 @@ export const getSignatureStatuses: RpcMethodHandler = async (
|
|
|
7
7
|
) => {
|
|
8
8
|
const [signatures] = params;
|
|
9
9
|
|
|
10
|
-
let persisted: Map<string, { slot: number; err:
|
|
10
|
+
let persisted: Map<string, { slot: number; err: unknown | null }> = new Map();
|
|
11
11
|
try {
|
|
12
12
|
persisted = (await context.store?.getStatuses(signatures)) || new Map();
|
|
13
13
|
} catch {}
|
|
@@ -17,7 +17,7 @@ export const getSignatureStatuses: RpcMethodHandler = async (
|
|
|
17
17
|
// Prefer locally recorded transactions for reliability with CLI tooling
|
|
18
18
|
const rec = context.getRecordedTransaction(sig);
|
|
19
19
|
if (rec) {
|
|
20
|
-
const errVal:
|
|
20
|
+
const errVal: unknown = rec.err ?? null;
|
|
21
21
|
const status = errVal ? { Err: errVal } : { Ok: null };
|
|
22
22
|
return {
|
|
23
23
|
slot: rec.slot,
|
|
@@ -29,7 +29,7 @@ export const getSignatureStatuses: RpcMethodHandler = async (
|
|
|
29
29
|
}
|
|
30
30
|
const db = persisted.get(sig);
|
|
31
31
|
if (db) {
|
|
32
|
-
const errVal:
|
|
32
|
+
const errVal: unknown = db.err ?? null;
|
|
33
33
|
const status = errVal ? { Err: errVal } : { Ok: null };
|
|
34
34
|
return {
|
|
35
35
|
slot: db.slot,
|
|
@@ -41,13 +41,20 @@ export const getSignatureStatuses: RpcMethodHandler = async (
|
|
|
41
41
|
}
|
|
42
42
|
|
|
43
43
|
const sigBytes = context.decodeBase58(sig);
|
|
44
|
-
const
|
|
44
|
+
const txGetter = (
|
|
45
|
+
context.svm as unknown as {
|
|
46
|
+
getTransaction?: (sig: Uint8Array) => { err?: unknown } | undefined;
|
|
47
|
+
}
|
|
48
|
+
).getTransaction;
|
|
49
|
+
const tx =
|
|
50
|
+
typeof txGetter === "function" ? txGetter(sigBytes) : undefined;
|
|
45
51
|
if (!tx) return null;
|
|
46
52
|
|
|
47
|
-
let errVal:
|
|
53
|
+
let errVal: unknown = null;
|
|
48
54
|
try {
|
|
49
|
-
|
|
50
|
-
errVal =
|
|
55
|
+
const rawErr = (tx as { err?: unknown }).err;
|
|
56
|
+
errVal =
|
|
57
|
+
typeof rawErr === "function" ? (rawErr as () => unknown)() : rawErr;
|
|
51
58
|
} catch {
|
|
52
59
|
errVal = null;
|
|
53
60
|
}
|
|
@@ -31,15 +31,11 @@ export const getSignaturesForAddress: RpcMethodHandler = async (
|
|
|
31
31
|
// Graceful fallback: return empty list instead of error
|
|
32
32
|
return context.createSuccessResponse(id, []);
|
|
33
33
|
}
|
|
34
|
-
} catch (error:
|
|
34
|
+
} catch (error: unknown) {
|
|
35
35
|
try {
|
|
36
36
|
console.error("[rpc] getSignaturesForAddress error", error);
|
|
37
37
|
} catch {}
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
-32603,
|
|
41
|
-
"Internal error",
|
|
42
|
-
error.message,
|
|
43
|
-
);
|
|
38
|
+
const message = error instanceof Error ? error.message : String(error);
|
|
39
|
+
return context.createErrorResponse(id, -32603, "Internal error", message);
|
|
44
40
|
}
|
|
45
41
|
};
|