@huma-finance/permissionless-sdk 1.0.0-beta.20250904172049.4e46e03
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/dist/idl/permissionless-devnet.json +6229 -0
- package/dist/idl/permissionless.d.ts +7524 -0
- package/dist/idl/permissionless.d.ts.map +1 -0
- package/dist/idl/permissionless.js +3 -0
- package/dist/idl/permissionless.js.map +1 -0
- package/dist/idl/permissionless.json +6207 -0
- package/dist/index.d.ts +9 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +25 -0
- package/dist/index.js.map +1 -0
- package/dist/permissionless/client.d.ts +14 -0
- package/dist/permissionless/client.d.ts.map +1 -0
- package/dist/permissionless/client.js +68 -0
- package/dist/permissionless/client.js.map +1 -0
- package/dist/types/chain.d.ts +6 -0
- package/dist/types/chain.d.ts.map +1 -0
- package/dist/types/chain.js +10 -0
- package/dist/types/chain.js.map +1 -0
- package/dist/types/deposit.d.ts +6 -0
- package/dist/types/deposit.d.ts.map +1 -0
- package/dist/types/deposit.js +10 -0
- package/dist/types/deposit.js.map +1 -0
- package/dist/types/metadata.d.ts +43 -0
- package/dist/types/metadata.d.ts.map +1 -0
- package/dist/types/metadata.js +9 -0
- package/dist/types/metadata.js.map +1 -0
- package/dist/utils/lenderAccount.d.ts +13 -0
- package/dist/utils/lenderAccount.d.ts.map +1 -0
- package/dist/utils/lenderAccount.js +37 -0
- package/dist/utils/lenderAccount.js.map +1 -0
- package/dist/utils/metadata.d.ts +4 -0
- package/dist/utils/metadata.d.ts.map +1 -0
- package/dist/utils/metadata.js +119 -0
- package/dist/utils/metadata.js.map +1 -0
- package/dist/utils/program.d.ts +6 -0
- package/dist/utils/program.d.ts.map +1 -0
- package/dist/utils/program.js +19 -0
- package/dist/utils/program.js.map +1 -0
- package/dist/utils/tokenAccount.d.ts +3 -0
- package/dist/utils/tokenAccount.d.ts.map +1 -0
- package/dist/utils/tokenAccount.js +9 -0
- package/dist/utils/tokenAccount.js.map +1 -0
- package/package.json +40 -0
package/dist/index.d.ts
ADDED
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
export * from "./permissionless/client";
|
|
2
|
+
export * from "./types/chain";
|
|
3
|
+
export * from "./types/deposit";
|
|
4
|
+
export * from "./types/metadata";
|
|
5
|
+
export * from "./utils/lenderAccount";
|
|
6
|
+
export * from "./utils/metadata";
|
|
7
|
+
export * from "./utils/program";
|
|
8
|
+
export * from "./utils/tokenAccount";
|
|
9
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,yBAAyB,CAAC;AACxC,cAAc,eAAe,CAAC;AAC9B,cAAc,iBAAiB,CAAC;AAChC,cAAc,kBAAkB,CAAC;AACjC,cAAc,uBAAuB,CAAC;AACtC,cAAc,kBAAkB,CAAC;AACjC,cAAc,iBAAiB,CAAC;AAChC,cAAc,sBAAsB,CAAC"}
|
package/dist/index.js
ADDED
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./permissionless/client"), exports);
|
|
18
|
+
__exportStar(require("./types/chain"), exports);
|
|
19
|
+
__exportStar(require("./types/deposit"), exports);
|
|
20
|
+
__exportStar(require("./types/metadata"), exports);
|
|
21
|
+
__exportStar(require("./utils/lenderAccount"), exports);
|
|
22
|
+
__exportStar(require("./utils/metadata"), exports);
|
|
23
|
+
__exportStar(require("./utils/program"), exports);
|
|
24
|
+
__exportStar(require("./utils/tokenAccount"), exports);
|
|
25
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,0DAAwC;AACxC,gDAA8B;AAC9B,kDAAgC;AAChC,mDAAiC;AACjC,wDAAsC;AACtC,mDAAiC;AACjC,kDAAgC;AAChC,uDAAqC"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { Connection, PublicKey, Transaction } from "@solana/web3.js";
|
|
2
|
+
import { SolanaChainEnum } from "../types/chain";
|
|
3
|
+
import { DepositMode } from "../types/metadata";
|
|
4
|
+
import { BN } from "@coral-xyz/anchor";
|
|
5
|
+
import { DepositCommitment } from "../types/deposit";
|
|
6
|
+
export declare class PermissionlessClient {
|
|
7
|
+
private connection;
|
|
8
|
+
private chain;
|
|
9
|
+
private metadata;
|
|
10
|
+
private program;
|
|
11
|
+
constructor(connection: Connection, chain: SolanaChainEnum);
|
|
12
|
+
buildDepositTx(owner: PublicKey, amount: BN, mode: DepositMode, commitment?: DepositCommitment): Promise<Transaction>;
|
|
13
|
+
}
|
|
14
|
+
//# sourceMappingURL=client.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"client.d.ts","sourceRoot":"","sources":["../../src/permissionless/client.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AACrE,OAAO,EAAE,eAAe,EAAE,MAAM,gBAAgB,CAAC;AACjD,OAAO,EAAE,WAAW,EAAkB,MAAM,mBAAmB,CAAC;AAQhE,OAAO,EAAE,EAAE,EAAwB,MAAM,mBAAmB,CAAC;AAG7D,OAAO,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAC;AAErD,qBAAa,oBAAoB;IAC/B,OAAO,CAAC,UAAU,CAAa;IAC/B,OAAO,CAAC,KAAK,CAAkB;IAC/B,OAAO,CAAC,QAAQ,CAAiB;IACjC,OAAO,CAAC,OAAO,CAA0B;gBAE7B,UAAU,EAAE,UAAU,EAAE,KAAK,EAAE,eAAe;IAOpD,cAAc,CAClB,KAAK,EAAE,SAAS,EAChB,MAAM,EAAE,EAAE,EACV,IAAI,EAAE,WAAW,EACjB,UAAU,GAAE,iBAA+C,GAC1D,OAAO,CAAC,WAAW,CAAC;CA4DxB"}
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.PermissionlessClient = void 0;
|
|
4
|
+
const web3_js_1 = require("@solana/web3.js");
|
|
5
|
+
const metadata_1 = require("../types/metadata");
|
|
6
|
+
const metadata_2 = require("../utils/metadata");
|
|
7
|
+
const spl_token_1 = require("@solana/spl-token");
|
|
8
|
+
const lenderAccount_1 = require("../utils/lenderAccount");
|
|
9
|
+
const program_1 = require("../utils/program");
|
|
10
|
+
const tokenAccount_1 = require("../utils/tokenAccount");
|
|
11
|
+
const deposit_1 = require("../types/deposit");
|
|
12
|
+
class PermissionlessClient {
|
|
13
|
+
connection;
|
|
14
|
+
chain;
|
|
15
|
+
metadata;
|
|
16
|
+
program;
|
|
17
|
+
constructor(connection, chain) {
|
|
18
|
+
this.connection = connection;
|
|
19
|
+
this.chain = chain;
|
|
20
|
+
this.metadata = (0, metadata_2.getMetadata)(chain);
|
|
21
|
+
this.program = (0, program_1.getHumaProgram)(connection, chain);
|
|
22
|
+
}
|
|
23
|
+
async buildDepositTx(owner, amount, mode, commitment = deposit_1.DepositCommitment.NO_COMMIT) {
|
|
24
|
+
const modeMetadata = this.metadata[mode];
|
|
25
|
+
const tx = new web3_js_1.Transaction();
|
|
26
|
+
const { classicLenderStateAccount, maxiLenderStateAccount } = await (0, lenderAccount_1.getLenderStateAccounts)(this.connection, owner, this.chain);
|
|
27
|
+
const lenderModeTokenATA = (0, tokenAccount_1.getModeTokenATA)(owner, new web3_js_1.PublicKey(modeMetadata.mint));
|
|
28
|
+
let lenderStateAccount;
|
|
29
|
+
if (mode === metadata_1.DepositMode.CLASSIC) {
|
|
30
|
+
lenderStateAccount = classicLenderStateAccount;
|
|
31
|
+
}
|
|
32
|
+
else {
|
|
33
|
+
lenderStateAccount = maxiLenderStateAccount;
|
|
34
|
+
}
|
|
35
|
+
if (!lenderStateAccount) {
|
|
36
|
+
const createLenderAccountInstruction = await this.program.methods
|
|
37
|
+
.createLenderAccounts()
|
|
38
|
+
.accountsPartial({
|
|
39
|
+
lender: owner,
|
|
40
|
+
humaConfig: this.metadata.humaConfig,
|
|
41
|
+
poolConfig: this.metadata.poolConfig,
|
|
42
|
+
modeConfig: modeMetadata.config,
|
|
43
|
+
lenderModeToken: lenderModeTokenATA,
|
|
44
|
+
tokenProgram: spl_token_1.TOKEN_PROGRAM_ID,
|
|
45
|
+
})
|
|
46
|
+
.instruction();
|
|
47
|
+
tx.add(createLenderAccountInstruction);
|
|
48
|
+
}
|
|
49
|
+
tx.add((0, spl_token_1.createAssociatedTokenAccountIdempotentInstruction)(owner, lenderModeTokenATA, owner, new web3_js_1.PublicKey(modeMetadata.mint), spl_token_1.TOKEN_PROGRAM_ID));
|
|
50
|
+
console.log(this.metadata.humaConfig);
|
|
51
|
+
const depositTx = await this.program.methods
|
|
52
|
+
.deposit(amount, commitment, false /* commitmentAutoRenewal */)
|
|
53
|
+
.accountsPartial({
|
|
54
|
+
depositor: owner,
|
|
55
|
+
humaConfig: this.metadata.humaConfig,
|
|
56
|
+
poolConfig: this.metadata.poolConfig,
|
|
57
|
+
modeConfig: modeMetadata.config,
|
|
58
|
+
underlyingMint: new web3_js_1.PublicKey(this.metadata.underlyingMint.address),
|
|
59
|
+
underlyingTokenProgram: spl_token_1.TOKEN_PROGRAM_ID,
|
|
60
|
+
modeTokenProgram: spl_token_1.TOKEN_PROGRAM_ID,
|
|
61
|
+
})
|
|
62
|
+
.instruction();
|
|
63
|
+
tx.add(depositTx);
|
|
64
|
+
return tx;
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
exports.PermissionlessClient = PermissionlessClient;
|
|
68
|
+
//# sourceMappingURL=client.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"client.js","sourceRoot":"","sources":["../../src/permissionless/client.ts"],"names":[],"mappings":";;;AAAA,6CAAqE;AAErE,gDAAgE;AAChE,gDAAgD;AAChD,iDAG2B;AAC3B,0DAAgE;AAGhE,8CAAkD;AAClD,wDAAwD;AACxD,8CAAqD;AAErD,MAAa,oBAAoB;IACvB,UAAU,CAAa;IACvB,KAAK,CAAkB;IACvB,QAAQ,CAAiB;IACzB,OAAO,CAA0B;IAEzC,YAAY,UAAsB,EAAE,KAAsB;QACxD,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;QAC7B,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,QAAQ,GAAG,IAAA,sBAAW,EAAC,KAAK,CAAC,CAAC;QACnC,IAAI,CAAC,OAAO,GAAG,IAAA,wBAAc,EAAC,UAAU,EAAE,KAAK,CAAC,CAAC;IACnD,CAAC;IAED,KAAK,CAAC,cAAc,CAClB,KAAgB,EAChB,MAAU,EACV,IAAiB,EACjB,aAAgC,2BAAiB,CAAC,SAAS;QAE3D,MAAM,YAAY,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;QACzC,MAAM,EAAE,GAAG,IAAI,qBAAW,EAAE,CAAC;QAE7B,MAAM,EAAE,yBAAyB,EAAE,sBAAsB,EAAE,GACzD,MAAM,IAAA,sCAAsB,EAAC,IAAI,CAAC,UAAU,EAAE,KAAK,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC;QACnE,MAAM,kBAAkB,GAAG,IAAA,8BAAe,EACxC,KAAK,EACL,IAAI,mBAAS,CAAC,YAAY,CAAC,IAAI,CAAC,CACjC,CAAC;QACF,IAAI,kBAAqE,CAAC;QAC1E,IAAI,IAAI,KAAK,sBAAW,CAAC,OAAO,EAAE,CAAC;YACjC,kBAAkB,GAAG,yBAAyB,CAAC;QACjD,CAAC;aAAM,CAAC;YACN,kBAAkB,GAAG,sBAAsB,CAAC;QAC9C,CAAC;QAED,IAAI,CAAC,kBAAkB,EAAE,CAAC;YACxB,MAAM,8BAA8B,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,OAAO;iBAC9D,oBAAoB,EAAE;iBACtB,eAAe,CAAC;gBACf,MAAM,EAAE,KAAK;gBACb,UAAU,EAAE,IAAI,CAAC,QAAQ,CAAC,UAAU;gBACpC,UAAU,EAAE,IAAI,CAAC,QAAQ,CAAC,UAAU;gBACpC,UAAU,EAAE,YAAY,CAAC,MAAM;gBAC/B,eAAe,EAAE,kBAAkB;gBACnC,YAAY,EAAE,4BAAgB;aAC/B,CAAC;iBACD,WAAW,EAAE,CAAC;YAEjB,EAAE,CAAC,GAAG,CAAC,8BAA8B,CAAC,CAAC;QACzC,CAAC;QAED,EAAE,CAAC,GAAG,CACJ,IAAA,6DAAiD,EAC/C,KAAK,EACL,kBAAkB,EAClB,KAAK,EACL,IAAI,mBAAS,CAAC,YAAY,CAAC,IAAI,CAAC,EAChC,4BAAgB,CACjB,CACF,CAAC;QAEF,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC;QACtC,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,OAAO;aACzC,OAAO,CAAC,MAAM,EAAE,UAAU,EAAE,KAAK,CAAC,2BAA2B,CAAC;aAC9D,eAAe,CAAC;YACf,SAAS,EAAE,KAAK;YAChB,UAAU,EAAE,IAAI,CAAC,QAAQ,CAAC,UAAU;YACpC,UAAU,EAAE,IAAI,CAAC,QAAQ,CAAC,UAAU;YACpC,UAAU,EAAE,YAAY,CAAC,MAAM;YAC/B,cAAc,EAAE,IAAI,mBAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,OAAO,CAAC;YACnE,sBAAsB,EAAE,4BAAgB;YACxC,gBAAgB,EAAE,4BAAgB;SACnC,CAAC;aACD,WAAW,EAAE,CAAC;QACjB,EAAE,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;QAElB,OAAO,EAAE,CAAC;IACZ,CAAC;CACF;AA9ED,oDA8EC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"chain.d.ts","sourceRoot":"","sources":["../../src/types/chain.ts"],"names":[],"mappings":"AAAA,oBAAY,eAAe;IACzB,MAAM,WAAW;IACjB,OAAO,YAAY;IACnB,OAAO,YAAY;CACpB"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.SolanaChainEnum = void 0;
|
|
4
|
+
var SolanaChainEnum;
|
|
5
|
+
(function (SolanaChainEnum) {
|
|
6
|
+
SolanaChainEnum["DEVNET"] = "devnet";
|
|
7
|
+
SolanaChainEnum["STAGING"] = "staging";
|
|
8
|
+
SolanaChainEnum["MAINNET"] = "mainnet";
|
|
9
|
+
})(SolanaChainEnum || (exports.SolanaChainEnum = SolanaChainEnum = {}));
|
|
10
|
+
//# sourceMappingURL=chain.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"chain.js","sourceRoot":"","sources":["../../src/types/chain.ts"],"names":[],"mappings":";;;AAAA,IAAY,eAIX;AAJD,WAAY,eAAe;IACzB,oCAAiB,CAAA;IACjB,sCAAmB,CAAA;IACnB,sCAAmB,CAAA;AACrB,CAAC,EAJW,eAAe,+BAAf,eAAe,QAI1B"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"deposit.d.ts","sourceRoot":"","sources":["../../src/types/deposit.ts"],"names":[],"mappings":"AAAA,oBAAY,iBAAiB;IAC3B,SAAS,kBAAkB;IAC3B,+BAA+B,oCAAoC;IACnE,6BAA6B,kCAAkC;CAChE"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.DepositCommitment = void 0;
|
|
4
|
+
var DepositCommitment;
|
|
5
|
+
(function (DepositCommitment) {
|
|
6
|
+
DepositCommitment["NO_COMMIT"] = "NO_COMMITMENT";
|
|
7
|
+
DepositCommitment["INITIAL_COMMITMENT_THREE_MONTHS"] = "INITIAL_COMMITMENT_THREE_MONTHS";
|
|
8
|
+
DepositCommitment["INITIAL_COMMITMENT_SIX_MONTHS"] = "INITIAL_COMMITMENT_SIX_MONTHS";
|
|
9
|
+
})(DepositCommitment || (exports.DepositCommitment = DepositCommitment = {}));
|
|
10
|
+
//# sourceMappingURL=deposit.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"deposit.js","sourceRoot":"","sources":["../../src/types/deposit.ts"],"names":[],"mappings":";;;AAAA,IAAY,iBAIX;AAJD,WAAY,iBAAiB;IAC3B,gDAA2B,CAAA;IAC3B,wFAAmE,CAAA;IACnE,oFAA+D,CAAA;AACjE,CAAC,EAJW,iBAAiB,iCAAjB,iBAAiB,QAI5B"}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
export declare enum DepositMode {
|
|
2
|
+
CLASSIC = "classic",
|
|
3
|
+
MAXI = "maxi"
|
|
4
|
+
}
|
|
5
|
+
export interface SolanaPoolInfo {
|
|
6
|
+
poolProgram: string;
|
|
7
|
+
humaConfig: string;
|
|
8
|
+
poolConfig: string;
|
|
9
|
+
poolState: string;
|
|
10
|
+
classicModeConfig: string;
|
|
11
|
+
classicModeMint: string;
|
|
12
|
+
maxiModeConfig: string;
|
|
13
|
+
maxiModeMint: string;
|
|
14
|
+
jupiterFeeAccount: string;
|
|
15
|
+
[DepositMode.CLASSIC]: {
|
|
16
|
+
config: string;
|
|
17
|
+
mint: string;
|
|
18
|
+
};
|
|
19
|
+
[DepositMode.MAXI]: {
|
|
20
|
+
config: string;
|
|
21
|
+
mint: string;
|
|
22
|
+
};
|
|
23
|
+
underlyingMint: {
|
|
24
|
+
address: string;
|
|
25
|
+
symbol: string;
|
|
26
|
+
decimals: number;
|
|
27
|
+
icon: string;
|
|
28
|
+
};
|
|
29
|
+
humaMint: {
|
|
30
|
+
address: string;
|
|
31
|
+
symbol: string;
|
|
32
|
+
decimals: number;
|
|
33
|
+
};
|
|
34
|
+
voteStakeRegistry: {
|
|
35
|
+
program: string;
|
|
36
|
+
registrar: string;
|
|
37
|
+
governanceProgramId: string;
|
|
38
|
+
realm: string;
|
|
39
|
+
};
|
|
40
|
+
lookupTable: string;
|
|
41
|
+
}
|
|
42
|
+
export type SolanaPoolInfoPartial = Omit<SolanaPoolInfo, DepositMode.CLASSIC | DepositMode.MAXI>;
|
|
43
|
+
//# sourceMappingURL=metadata.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"metadata.d.ts","sourceRoot":"","sources":["../../src/types/metadata.ts"],"names":[],"mappings":"AAAA,oBAAY,WAAW;IACrB,OAAO,YAAY;IACnB,IAAI,SAAS;CACd;AAED,MAAM,WAAW,cAAc;IAC7B,WAAW,EAAE,MAAM,CAAC;IACpB,UAAU,EAAE,MAAM,CAAC;IACnB,UAAU,EAAE,MAAM,CAAC;IACnB,SAAS,EAAE,MAAM,CAAC;IAClB,iBAAiB,EAAE,MAAM,CAAC;IAC1B,eAAe,EAAE,MAAM,CAAC;IACxB,cAAc,EAAE,MAAM,CAAC;IACvB,YAAY,EAAE,MAAM,CAAC;IACrB,iBAAiB,EAAE,MAAM,CAAC;IAC1B,CAAC,WAAW,CAAC,OAAO,CAAC,EAAE;QACrB,MAAM,EAAE,MAAM,CAAC;QACf,IAAI,EAAE,MAAM,CAAC;KACd,CAAC;IACF,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE;QAClB,MAAM,EAAE,MAAM,CAAC;QACf,IAAI,EAAE,MAAM,CAAC;KACd,CAAC;IACF,cAAc,EAAE;QACd,OAAO,EAAE,MAAM,CAAC;QAChB,MAAM,EAAE,MAAM,CAAC;QACf,QAAQ,EAAE,MAAM,CAAC;QACjB,IAAI,EAAE,MAAM,CAAC;KACd,CAAC;IACF,QAAQ,EAAE;QACR,OAAO,EAAE,MAAM,CAAC;QAChB,MAAM,EAAE,MAAM,CAAC;QACf,QAAQ,EAAE,MAAM,CAAC;KAClB,CAAC;IACF,iBAAiB,EAAE;QACjB,OAAO,EAAE,MAAM,CAAC;QAChB,SAAS,EAAE,MAAM,CAAC;QAClB,mBAAmB,EAAE,MAAM,CAAC;QAC5B,KAAK,EAAE,MAAM,CAAC;KACf,CAAC;IACF,WAAW,EAAE,MAAM,CAAC;CACrB;AAED,MAAM,MAAM,qBAAqB,GAAG,IAAI,CACtC,cAAc,EACd,WAAW,CAAC,OAAO,GAAG,WAAW,CAAC,IAAI,CACvC,CAAC"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.DepositMode = void 0;
|
|
4
|
+
var DepositMode;
|
|
5
|
+
(function (DepositMode) {
|
|
6
|
+
DepositMode["CLASSIC"] = "classic";
|
|
7
|
+
DepositMode["MAXI"] = "maxi";
|
|
8
|
+
})(DepositMode || (exports.DepositMode = DepositMode = {}));
|
|
9
|
+
//# sourceMappingURL=metadata.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"metadata.js","sourceRoot":"","sources":["../../src/types/metadata.ts"],"names":[],"mappings":";;;AAAA,IAAY,WAGX;AAHD,WAAY,WAAW;IACrB,kCAAmB,CAAA;IACnB,4BAAa,CAAA;AACf,CAAC,EAHW,WAAW,2BAAX,WAAW,QAGtB"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { Connection, PublicKey } from "@solana/web3.js";
|
|
2
|
+
import { SolanaChainEnum } from "../types/chain";
|
|
3
|
+
import { IdlAccounts } from "@coral-xyz/anchor";
|
|
4
|
+
import { Permissionless } from "../idl/permissionless";
|
|
5
|
+
export declare function getLenderStatePDAs(lender: PublicKey, chain: SolanaChainEnum): {
|
|
6
|
+
classicLenderStateAccountPDA: PublicKey;
|
|
7
|
+
maxiLenderStateAccountPDA: PublicKey;
|
|
8
|
+
};
|
|
9
|
+
export declare function getLenderStateAccounts(connection: Connection, lender: PublicKey, chain: SolanaChainEnum): Promise<{
|
|
10
|
+
classicLenderStateAccount: IdlAccounts<Permissionless>["lenderState"] | null;
|
|
11
|
+
maxiLenderStateAccount: IdlAccounts<Permissionless>["lenderState"] | null;
|
|
12
|
+
}>;
|
|
13
|
+
//# sourceMappingURL=lenderAccount.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"lenderAccount.d.ts","sourceRoot":"","sources":["../../src/utils/lenderAccount.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAExD,OAAO,EAAE,eAAe,EAAE,MAAM,gBAAgB,CAAC;AAGjD,OAAO,EAAE,WAAW,EAAkB,MAAM,mBAAmB,CAAC;AAChE,OAAO,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AAEvD,wBAAgB,kBAAkB,CAChC,MAAM,EAAE,SAAS,EACjB,KAAK,EAAE,eAAe,GACrB;IACD,4BAA4B,EAAE,SAAS,CAAC;IACxC,yBAAyB,EAAE,SAAS,CAAC;CACtC,CAuBA;AAED,wBAAsB,sBAAsB,CAC1C,UAAU,EAAE,UAAU,EACtB,MAAM,EAAE,SAAS,EACjB,KAAK,EAAE,eAAe,GACrB,OAAO,CAAC;IACT,yBAAyB,EAAE,WAAW,CAAC,cAAc,CAAC,CAAC,aAAa,CAAC,GAAG,IAAI,CAAC;IAC7E,sBAAsB,EAAE,WAAW,CAAC,cAAc,CAAC,CAAC,aAAa,CAAC,GAAG,IAAI,CAAC;CAC3E,CAAC,CAeD"}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.getLenderStatePDAs = getLenderStatePDAs;
|
|
4
|
+
exports.getLenderStateAccounts = getLenderStateAccounts;
|
|
5
|
+
const web3_js_1 = require("@solana/web3.js");
|
|
6
|
+
const metadata_1 = require("../types/metadata");
|
|
7
|
+
const metadata_2 = require("./metadata");
|
|
8
|
+
const program_1 = require("./program");
|
|
9
|
+
function getLenderStatePDAs(lender, chain) {
|
|
10
|
+
const metadata = (0, metadata_2.getMetadata)(chain);
|
|
11
|
+
const [classicLenderStateAccountPDA] = web3_js_1.PublicKey.findProgramAddressSync([
|
|
12
|
+
Buffer.from("lender_state"),
|
|
13
|
+
new web3_js_1.PublicKey(metadata[metadata_1.DepositMode.CLASSIC].config).toBuffer(),
|
|
14
|
+
lender.toBuffer(),
|
|
15
|
+
], new web3_js_1.PublicKey(metadata.poolProgram));
|
|
16
|
+
const [maxiLenderStateAccountPDA] = web3_js_1.PublicKey.findProgramAddressSync([
|
|
17
|
+
Buffer.from("lender_state"),
|
|
18
|
+
new web3_js_1.PublicKey(metadata[metadata_1.DepositMode.MAXI].config).toBuffer(),
|
|
19
|
+
lender.toBuffer(),
|
|
20
|
+
], new web3_js_1.PublicKey(metadata.poolProgram));
|
|
21
|
+
return {
|
|
22
|
+
classicLenderStateAccountPDA,
|
|
23
|
+
maxiLenderStateAccountPDA,
|
|
24
|
+
};
|
|
25
|
+
}
|
|
26
|
+
async function getLenderStateAccounts(connection, lender, chain) {
|
|
27
|
+
const { classicLenderStateAccountPDA, maxiLenderStateAccountPDA } = getLenderStatePDAs(lender, chain);
|
|
28
|
+
const lenderStateAccounts = await (0, program_1.getHumaProgram)(connection, chain).account.lenderState.fetchMultiple([
|
|
29
|
+
classicLenderStateAccountPDA,
|
|
30
|
+
maxiLenderStateAccountPDA,
|
|
31
|
+
]);
|
|
32
|
+
return {
|
|
33
|
+
classicLenderStateAccount: lenderStateAccounts[0],
|
|
34
|
+
maxiLenderStateAccount: lenderStateAccounts[1],
|
|
35
|
+
};
|
|
36
|
+
}
|
|
37
|
+
//# sourceMappingURL=lenderAccount.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"lenderAccount.js","sourceRoot":"","sources":["../../src/utils/lenderAccount.ts"],"names":[],"mappings":";;AAQA,gDA6BC;AAED,wDAsBC;AA7DD,6CAAwD;AACxD,gDAAgD;AAEhD,yCAAyC;AACzC,uCAA2C;AAI3C,SAAgB,kBAAkB,CAChC,MAAiB,EACjB,KAAsB;IAKtB,MAAM,QAAQ,GAAG,IAAA,sBAAW,EAAC,KAAK,CAAC,CAAC;IACpC,MAAM,CAAC,4BAA4B,CAAC,GAAG,mBAAS,CAAC,sBAAsB,CACrE;QACE,MAAM,CAAC,IAAI,CAAC,cAAc,CAAC;QAC3B,IAAI,mBAAS,CAAC,QAAQ,CAAC,sBAAW,CAAC,OAAO,CAAC,CAAC,MAAM,CAAC,CAAC,QAAQ,EAAE;QAC9D,MAAM,CAAC,QAAQ,EAAE;KAClB,EACD,IAAI,mBAAS,CAAC,QAAQ,CAAC,WAAW,CAAC,CACpC,CAAC;IACF,MAAM,CAAC,yBAAyB,CAAC,GAAG,mBAAS,CAAC,sBAAsB,CAClE;QACE,MAAM,CAAC,IAAI,CAAC,cAAc,CAAC;QAC3B,IAAI,mBAAS,CAAC,QAAQ,CAAC,sBAAW,CAAC,IAAI,CAAC,CAAC,MAAM,CAAC,CAAC,QAAQ,EAAE;QAC3D,MAAM,CAAC,QAAQ,EAAE;KAClB,EACD,IAAI,mBAAS,CAAC,QAAQ,CAAC,WAAW,CAAC,CACpC,CAAC;IAEF,OAAO;QACL,4BAA4B;QAC5B,yBAAyB;KAC1B,CAAC;AACJ,CAAC;AAEM,KAAK,UAAU,sBAAsB,CAC1C,UAAsB,EACtB,MAAiB,EACjB,KAAsB;IAKtB,MAAM,EAAE,4BAA4B,EAAE,yBAAyB,EAAE,GAC/D,kBAAkB,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;IACpC,MAAM,mBAAmB,GAAG,MAAM,IAAA,wBAAc,EAC9C,UAAU,EACV,KAAK,CACN,CAAC,OAAO,CAAC,WAAW,CAAC,aAAa,CAAC;QAClC,4BAA4B;QAC5B,yBAAyB;KAC1B,CAAC,CAAC;IAEH,OAAO;QACL,yBAAyB,EAAE,mBAAmB,CAAC,CAAC,CAAC;QACjD,sBAAsB,EAAE,mBAAmB,CAAC,CAAC,CAAC;KAC/C,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"metadata.d.ts","sourceRoot":"","sources":["../../src/utils/metadata.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,gBAAgB,CAAC;AACjD,OAAO,EAEL,cAAc,EAEf,MAAM,mBAAmB,CAAC;AA4F3B,wBAAgB,WAAW,CAAC,KAAK,EAAE,eAAe,GAAG,cAAc,CA2BlE"}
|
|
@@ -0,0 +1,119 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.getMetadata = getMetadata;
|
|
4
|
+
const metadata_1 = require("../types/metadata");
|
|
5
|
+
const DevnetMetadata = {
|
|
6
|
+
poolProgram: "ACQydQGziybxnN6dPAy3ssmYYbTp6K4rvwnBjjmh11Hj",
|
|
7
|
+
humaConfig: "F2it2fBcdjeX9KCaEAWcQ1H8LnMB2zPn3nrPpHc7J8vL",
|
|
8
|
+
poolConfig: "8bZkGVDziZLver5ZTa3whZqWhRTzTBiCXHhYnS1L7BCB",
|
|
9
|
+
poolState: "9tNHuAjsx3nZMWrLQrDMX5sKrMvNvZgXEo76U2C8NN3n",
|
|
10
|
+
classicModeConfig: "CdNvmFR73UoGAEPEgM4wMiVuhNDd3AAtsXhDfgPaECcy",
|
|
11
|
+
classicModeMint: "3kTT1x7H2tKSA6hJXdyZnQqwFrMvse4CoBttcMRuDXzS",
|
|
12
|
+
maxiModeConfig: "GYUW3PPU5nmBo2ZQ4AmPf3tJXmH3A7q8K3ns7MgsiGAw",
|
|
13
|
+
maxiModeMint: "CQRBRW29Mk6eiVoet7bgHhvQm6H4aPSdwErxaYkWvp1T",
|
|
14
|
+
jupiterFeeAccount: "4q62LyNGkPsuoWYLHe8zAhXmKRVvZJANvUWj21sq6wLN",
|
|
15
|
+
underlyingMint: {
|
|
16
|
+
address: "4zMMC9srt5Ri5X14GAgXhaHii3GnPAEERYPJgZJDncDU",
|
|
17
|
+
symbol: "USDC",
|
|
18
|
+
decimals: 6,
|
|
19
|
+
icon: "USDC",
|
|
20
|
+
},
|
|
21
|
+
humaMint: {
|
|
22
|
+
address: "HKSHLDGBMcFbTR8LDjXPfqQuSWT3X8BovCZJbkU96T1D",
|
|
23
|
+
symbol: "HUMA",
|
|
24
|
+
decimals: 6,
|
|
25
|
+
},
|
|
26
|
+
voteStakeRegistry: {
|
|
27
|
+
program: "vsRJM68m7i18PwzTFphgPYXTujCgxEi28knpUwSmg3q",
|
|
28
|
+
registrar: "Au2rdjSueLk7B6LjibHNRjTu1LyYkLqTv7Dmavet4P5x",
|
|
29
|
+
governanceProgramId: "GoV5KJUaLyKFiBn8SbmYhUoemXj6z5wvLLzeGkhyAg8h",
|
|
30
|
+
realm: "85a6Qq99q6vYyWrfSC8rMpxECo4BP1Fqxy2CoN7zjfDB",
|
|
31
|
+
},
|
|
32
|
+
lookupTable: "9vDNLLiESHhn6QrReghFX8HdymEDtxhBk6bN2FenuTWj",
|
|
33
|
+
};
|
|
34
|
+
const StagingMainnetMetadata = {
|
|
35
|
+
poolProgram: "HumaXepHnjaRCpjYTokxY4UtaJcmx41prQ8cxGmFC5fn",
|
|
36
|
+
humaConfig: "Fh2WKYCJfota6k76gDGnhTELUuhPa7FHQvVza4cE11ja",
|
|
37
|
+
poolConfig: "J9wzhwWtzdGUQxjy1cJh8mBfdRCxsNNaKNcEUcTcZxMU",
|
|
38
|
+
poolState: "E4tNzL2uPd2U7fxVe56g2rU19WWHmMTZM7Ci5kSfNHKK",
|
|
39
|
+
classicModeConfig: "CjcumTgszBPE5mJak1PbZTJwgfkC4t3yANSWQ1tkE4ea",
|
|
40
|
+
classicModeMint: "G7cU54P2sBsrAEBgFEiSeVFEM4egLAt74LkqSozPynCS",
|
|
41
|
+
maxiModeConfig: "62aTUium167wBD62DVwn6EbC658xECedZEsNmDiRMPDZ",
|
|
42
|
+
maxiModeMint: "HfLoRMcx6roD5Couts7caJxZ2rAJLBQb9mGWF9t1b2ZC",
|
|
43
|
+
jupiterFeeAccount: "4q62LyNGkPsuoWYLHe8zAhXmKRVvZJANvUWj21sq6wLN",
|
|
44
|
+
underlyingMint: {
|
|
45
|
+
address: "EPjFWdd5AufqSSqeM2qN1xzybapC8G4wEGGkZwyTDt1v",
|
|
46
|
+
symbol: "USDC",
|
|
47
|
+
decimals: 6,
|
|
48
|
+
icon: "USDC",
|
|
49
|
+
},
|
|
50
|
+
humaMint: {
|
|
51
|
+
address: "7p5HdsC9pKRVoMTfsbLqwPP1WJvRp5yQMLrp3dsRxBB",
|
|
52
|
+
symbol: "HUMA",
|
|
53
|
+
decimals: 6,
|
|
54
|
+
},
|
|
55
|
+
voteStakeRegistry: {
|
|
56
|
+
program: "vsRJM68m7i18PwzTFphgPYXTujCgxEi28knpUwSmg3q",
|
|
57
|
+
registrar: "AnTEBJRBJy4FoXKJ2zhM3E6Amnzo2a2A7zUuYnephRSF",
|
|
58
|
+
governanceProgramId: "Gov8EMLCrEgr1pWjsjR2GaMNU8A7SuyFam9GkFa4j8Xy",
|
|
59
|
+
realm: "7dv8cPksFqB23hzuV1xmp1uG2n1xhF7o3XiZKe8EtcV1",
|
|
60
|
+
},
|
|
61
|
+
lookupTable: "8PSRfzu9zBeuQpSQVaeJAxWrQxF7DxVNbC5isTD55pMX",
|
|
62
|
+
};
|
|
63
|
+
const MainnetMetadata = {
|
|
64
|
+
poolProgram: "HumaXepHnjaRCpjYTokxY4UtaJcmx41prQ8cxGmFC5fn",
|
|
65
|
+
humaConfig: "Fh2WKYCJfota6k76gDGnhTELUuhPa7FHQvVza4cE11ja",
|
|
66
|
+
poolConfig: "28hFhD21Nka3stL27a8zZ4nRLgaDVxRYwJgeEVgeakzS",
|
|
67
|
+
poolState: "iFgP2EbzHUZzMjqbjaagJQ8zmn6as3Hw95aVUKm67od",
|
|
68
|
+
classicModeConfig: "3FhoMDyKzQqxtGxnz9DfysfoGQKvgDnSFjoDGgguDCQN",
|
|
69
|
+
classicModeMint: "59obFNBzyTBGowrkif5uK7ojS58vsuWz3ZCvg6tfZAGw",
|
|
70
|
+
maxiModeConfig: "AcHvC47rpoMAY22CbHRpp7vsAskRyhyZGYQCqdm4BWcH",
|
|
71
|
+
maxiModeMint: "HUPfpnsaJtJGpJxAPNX1vXah7BgYiQYt1c2JMgMumvPs",
|
|
72
|
+
jupiterFeeAccount: "DvfdsU25qBwa3Yq6qMUrQkkfXXghZ11mfBSzKUD398mP",
|
|
73
|
+
underlyingMint: {
|
|
74
|
+
address: "EPjFWdd5AufqSSqeM2qN1xzybapC8G4wEGGkZwyTDt1v",
|
|
75
|
+
symbol: "USDC",
|
|
76
|
+
decimals: 6,
|
|
77
|
+
icon: "USDC",
|
|
78
|
+
},
|
|
79
|
+
humaMint: {
|
|
80
|
+
address: "HUMA1821qVDKta3u2ovmfDQeW2fSQouSKE8fkF44wvGw",
|
|
81
|
+
symbol: "HUMA",
|
|
82
|
+
decimals: 6,
|
|
83
|
+
},
|
|
84
|
+
voteStakeRegistry: {
|
|
85
|
+
program: "vsRJM68m7i18PwzTFphgPYXTujCgxEi28knpUwSmg3q",
|
|
86
|
+
registrar: "75SsBkPrpnXeXqyeFKhXwDbcqerxJpZmqmtESjPDVaVB",
|
|
87
|
+
governanceProgramId: "Gov8EMLCrEgr1pWjsjR2GaMNU8A7SuyFam9GkFa4j8Xy",
|
|
88
|
+
realm: "Fbg9VshdYgqqqqVj4teDi9hUNh8XeVhqrUJaHztSQAVZ",
|
|
89
|
+
},
|
|
90
|
+
lookupTable: "EnC4XkFPBGincyMHq1SSvfnxT5Cr44j9oikH4UMMkzBi",
|
|
91
|
+
};
|
|
92
|
+
function getMetadata(chain) {
|
|
93
|
+
let metadataPartial;
|
|
94
|
+
switch (chain) {
|
|
95
|
+
case "devnet":
|
|
96
|
+
metadataPartial = DevnetMetadata;
|
|
97
|
+
break;
|
|
98
|
+
case "staging":
|
|
99
|
+
metadataPartial = StagingMainnetMetadata;
|
|
100
|
+
break;
|
|
101
|
+
case "mainnet":
|
|
102
|
+
metadataPartial = MainnetMetadata;
|
|
103
|
+
break;
|
|
104
|
+
default:
|
|
105
|
+
throw new Error(`Invalid chain: ${chain}`);
|
|
106
|
+
}
|
|
107
|
+
return {
|
|
108
|
+
...metadataPartial,
|
|
109
|
+
[metadata_1.DepositMode.CLASSIC]: {
|
|
110
|
+
config: metadataPartial.classicModeConfig,
|
|
111
|
+
mint: metadataPartial.classicModeMint,
|
|
112
|
+
},
|
|
113
|
+
[metadata_1.DepositMode.MAXI]: {
|
|
114
|
+
config: metadataPartial.maxiModeConfig,
|
|
115
|
+
mint: metadataPartial.maxiModeMint,
|
|
116
|
+
},
|
|
117
|
+
};
|
|
118
|
+
}
|
|
119
|
+
//# sourceMappingURL=metadata.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"metadata.js","sourceRoot":"","sources":["../../src/utils/metadata.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { Connection } from "@solana/web3.js";
|
|
2
|
+
import { Permissionless } from "../idl/permissionless";
|
|
3
|
+
import { Program } from "@coral-xyz/anchor";
|
|
4
|
+
import { SolanaChainEnum } from "../types/chain";
|
|
5
|
+
export declare const getHumaProgram: (connection: Connection, chain: SolanaChainEnum) => Program<Permissionless>;
|
|
6
|
+
//# sourceMappingURL=program.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"program.d.ts","sourceRoot":"","sources":["../../src/utils/program.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAC7C,OAAO,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AAGvD,OAAO,EAAkB,OAAO,EAAE,MAAM,mBAAmB,CAAC;AAC5D,OAAO,EAAE,eAAe,EAAE,MAAM,gBAAgB,CAAC;AAEjD,eAAO,MAAM,cAAc,GACzB,YAAY,UAAU,EACtB,OAAO,eAAe,KACrB,OAAO,CAAC,cAAc,CASxB,CAAC"}
|
|
@@ -0,0 +1,19 @@
|
|
|
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.getHumaProgram = void 0;
|
|
7
|
+
const permissionless_json_1 = __importDefault(require("../idl/permissionless.json"));
|
|
8
|
+
const permissionless_devnet_json_1 = __importDefault(require("../idl/permissionless-devnet.json"));
|
|
9
|
+
const anchor_1 = require("@coral-xyz/anchor");
|
|
10
|
+
const chain_1 = require("../types/chain");
|
|
11
|
+
const getHumaProgram = (connection, chain) => {
|
|
12
|
+
// @ts-ignore
|
|
13
|
+
const provider = new anchor_1.AnchorProvider(connection, {}, {});
|
|
14
|
+
return new anchor_1.Program(chain === chain_1.SolanaChainEnum.DEVNET
|
|
15
|
+
? permissionless_devnet_json_1.default
|
|
16
|
+
: permissionless_json_1.default, provider);
|
|
17
|
+
};
|
|
18
|
+
exports.getHumaProgram = getHumaProgram;
|
|
19
|
+
//# sourceMappingURL=program.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"program.js","sourceRoot":"","sources":["../../src/utils/program.ts"],"names":[],"mappings":";;;;;;AAEA,qFAA2D;AAC3D,mGAAwE;AACxE,8CAA4D;AAC5D,0CAAiD;AAE1C,MAAM,cAAc,GAAG,CAC5B,UAAsB,EACtB,KAAsB,EACG,EAAE;IAC3B,aAAa;IACb,MAAM,QAAQ,GAAG,IAAI,uBAAc,CAAC,UAAU,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC;IACxD,OAAO,IAAI,gBAAO,CAChB,KAAK,KAAK,uBAAe,CAAC,MAAM;QAC9B,CAAC,CAAE,oCAA0C;QAC7C,CAAC,CAAE,6BAAoC,EACzC,QAAQ,CACT,CAAC;AACJ,CAAC,CAAC;AAZW,QAAA,cAAc,kBAYzB"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tokenAccount.d.ts","sourceRoot":"","sources":["../../src/utils/tokenAccount.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAE5C,wBAAgB,eAAe,CAC7B,SAAS,EAAE,SAAS,EACpB,QAAQ,EAAE,SAAS,GAClB,SAAS,CAOX"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.getModeTokenATA = getModeTokenATA;
|
|
4
|
+
const spl_token_1 = require("@solana/spl-token");
|
|
5
|
+
const web3_js_1 = require("@solana/web3.js");
|
|
6
|
+
function getModeTokenATA(publicKey, modeMint) {
|
|
7
|
+
return (0, spl_token_1.getAssociatedTokenAddressSync)(new web3_js_1.PublicKey(modeMint), publicKey, true, spl_token_1.TOKEN_PROGRAM_ID);
|
|
8
|
+
}
|
|
9
|
+
//# sourceMappingURL=tokenAccount.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tokenAccount.js","sourceRoot":"","sources":["../../src/utils/tokenAccount.ts"],"names":[],"mappings":";;AAMA,0CAUC;AAhBD,iDAG2B;AAC3B,6CAA4C;AAE5C,SAAgB,eAAe,CAC7B,SAAoB,EACpB,QAAmB;IAEnB,OAAO,IAAA,yCAA6B,EAClC,IAAI,mBAAS,CAAC,QAAQ,CAAC,EACvB,SAAS,EACT,IAAI,EACJ,4BAAgB,CACjB,CAAC;AACJ,CAAC"}
|
package/package.json
ADDED
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@huma-finance/permissionless-sdk",
|
|
3
|
+
"version": "1.0.0-beta.20250904172049.4e46e03",
|
|
4
|
+
"description": "Huma Finance Permissionless SDK for Solana",
|
|
5
|
+
"main": "dist/index.js",
|
|
6
|
+
"types": "dist/index.d.ts",
|
|
7
|
+
"files": [
|
|
8
|
+
"dist/**/*"
|
|
9
|
+
],
|
|
10
|
+
"publishConfig": {
|
|
11
|
+
"access": "public"
|
|
12
|
+
},
|
|
13
|
+
"keywords": [
|
|
14
|
+
"solana",
|
|
15
|
+
"defi",
|
|
16
|
+
"huma",
|
|
17
|
+
"permissionless",
|
|
18
|
+
"sdk"
|
|
19
|
+
],
|
|
20
|
+
"author": "Huma Finance",
|
|
21
|
+
"license": "MIT",
|
|
22
|
+
"dependencies": {
|
|
23
|
+
"@coral-xyz/anchor": "^0.31.1",
|
|
24
|
+
"@solana/spl-token": "^0.4.14",
|
|
25
|
+
"@solana/web3.js": "^1.98.4"
|
|
26
|
+
},
|
|
27
|
+
"devDependencies": {
|
|
28
|
+
"@types/jest": "^29.5.12",
|
|
29
|
+
"@types/node": "^24.3.0",
|
|
30
|
+
"dotenv": "^17.2.2",
|
|
31
|
+
"jest": "^29.7.0",
|
|
32
|
+
"ts-jest": "^29.1.2"
|
|
33
|
+
},
|
|
34
|
+
"scripts": {
|
|
35
|
+
"build": "tsc",
|
|
36
|
+
"test": "jest",
|
|
37
|
+
"test:watch": "jest --watch",
|
|
38
|
+
"test:coverage": "jest --coverage"
|
|
39
|
+
}
|
|
40
|
+
}
|