import {
createEncodeObject,
sunriseTypesRegistry,
} from "@sunriselayer/client";
// すべてのモジュールのスキーマと型はクライアントからエクスポートされます。
// ここでは、`MsgCreatePosition`メッセージのスキーマをインポートします。
import { MsgCreatePositionSchema } from "@sunriselayer/client/types/liquiditypool";
import { DirectSecp256k1HdWallet } from "@cosmjs/proto-signing";
import { SigningStargateClient, coin } from "@cosmjs/stargate";
const RPC = "https://goldberg-rpc.sunrise.node"; // ノードに置き換えてください
const SENDER_MNEMONIC = process.env.MNEMONIC!; // 秘密鍵は絶対にコミットしないでください
// これは簡略化された例です。実際のアプリケーションでは、クエリクライアントから
// プールの詳細を取得し、ユーザーが提供した価格からティックを計算します。
const MOCK_POOL_ID = 1n; // 注:uint64フィールドにはBigIntを使用してください
const MOCK_LOWER_TICK = -20000n;
const MOCK_UPPER_TICK = 20000n;
async function main() {
// 1. ニーモニックからウォレットと署名者を作成します
const signer = await DirectSecp256k1HdWallet.fromMnemonic(SENDER_MNEMONIC, {
prefix: "sunrise", // SunriseのBech32アドレスプレフィックス
});
const [account] = await signer.getAccounts();
const senderAddress = account.address;
console.log("送信者アドレス:", senderAddress);
// 2. 署名者と型レジストリを使用して署名クライアントを作成します
const client = await SigningStargateClient.connectWithSigner(RPC, signer, {
registry: sunriseTypesRegistry, // Sunriseメッセージのカスタム型レジストリ
});
console.log("正常に接続しました:", RPC);
// 3. 「Create Position」トランザクションメッセージを準備します
// すべてのメッセージフィールドは完全に型付けされ、検証されます。
const msg = createEncodeObject(MsgCreatePositionSchema, {
sender: senderAddress,
poolId: MOCK_POOL_ID,
lowerTick: MOCK_LOWER_TICK,
upperTick: MOCK_UPPER_TICK,
// @cosmjs/stargateの`coin`ヘルパーを使用してCoinオブジェクトを作成します
tokenBase: coin("1000000", "urise"), // 1 RISE
tokenQuote: coin("5000000", "uusdc"), // 5 USDC(例)
minAmountBase: "0", // スリッページ保護
minAmountQuote: "0", // スリッページ保護
});
// 4. 手数料を定義し、トランザクションに署名してブロードキャストします
const fee = {
amount: [coin("10000", "uusdrise")],
gas: "400000", // ガス制限
};
const memo = "Created position via @sunriselayer/client";
console.log("トランザクションをブロードキャストしています...");
const { transactionHash } = await client.signAndBroadcast(
senderAddress,
[msg],
fee,
memo
);
console.log("正常にポジションを作成しました!");
console.log("トランザクションハッシュ:", transactionHash);
}
main().catch(console.error);