Skip to content

Commit

Permalink
Merge branch 'main' of github.com:sygmaprotocol/sygma-sdk into lykhoy…
Browse files Browse the repository at this point in the history
…da/substrate_docs_update
  • Loading branch information
saadahmsiddiqui committed Oct 21, 2024
2 parents 30d09fd + 6ba1c2b commit b17e54b
Show file tree
Hide file tree
Showing 72 changed files with 1,014 additions and 187 deletions.
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import type { Environment } from '@buildwithsygma/core';
import type { Environment } from "@buildwithsygma/core";

declare global {
namespace NodeJS {
Expand Down
55 changes: 29 additions & 26 deletions examples/bitcoin-to-evm-fungible-transfer/src/transfer.p2tr.ts
Original file line number Diff line number Diff line change
@@ -1,19 +1,20 @@
import {
createBitcoinFungibleTransfer,
TypeOfAddress,
getPublicKey,
broadcastTransaction,
fetchUTXOS,
getFeeEstimates,
processUtxos,
} from "@buildwithsygma/bitcoin";
import type { BitcoinTransferParams, UTXOData } from "@buildwithsygma/bitcoin";
import { BIP32Factory } from "bip32";
import { mnemonicToSeed } from "bip39";
import { crypto, initEccLib, networks } from "bitcoinjs-lib";
import { toXOnly } from "bitcoinjs-lib/src/psbt/bip371";
import { initEccLib, networks, Signer } from "bitcoinjs-lib";
import dotenv from "dotenv";
import * as tinysecp from "tiny-secp256k1";
import { broadcastTransaction, fetchUTXOS, getFeeEstimates, processUtxos } from '@buildwithsygma/utils'

import {
calculateSize,
} from "./blockstreamApi.js";
import { calculateSize } from "./blockstreamApi.js";
import { Environment } from "@buildwithsygma/core";

dotenv.config();

Expand All @@ -30,7 +31,6 @@ const {
AMOUNT,
} = process.env;


if (
!SOURCE_CAIPID ||
!DESTINATION_ADDRESS ||
Expand All @@ -51,21 +51,22 @@ async function btcToEvmTransfer(): Promise<void> {
initEccLib(tinysecp);
const bip32 = BIP32Factory(tinysecp);
console.log("Transfer BTC to EVM");
const seed = await mnemonicToSeed(MNEMONIC);
const rootKey = bip32.fromSeed(seed, networks.testnet);
const derivedNode = rootKey.derivePath(DERIVATION_PATH);

const publicKeyDropedDERHeader = toXOnly(derivedNode.publicKey);

const tweakedSigner = derivedNode.tweak(
crypto.taggedHash("TapTweak", publicKeyDropedDERHeader),
);
const { tweakedSigner, publicKeyDropedDERHeader } = (await getPublicKey({
bip32,
mnemonic: MNEMONIC as string,
derivationPath: DERIVATION_PATH as string,
network: networks.testnet,
typeOfAddress: TypeOfAddress.P2TR,
})) as { publicKeyDropedDERHeader: Buffer; tweakedSigner: Signer };

const feeRate = await getFeeEstimates('5');
const feeRate = await getFeeEstimates(process.env.SYGMA_ENV, "5");
const utxos = await fetchUTXOS(
ADDRESS as unknown as string);
process.env.SYGMA_ENV,
ADDRESS as unknown as string
);

const processedUtxos = processUtxos(utxos, AMOUNT);
const processedUtxos = processUtxos(utxos, Number(BigInt(AMOUNT!)));

const mapedUtxos = processedUtxos.map((utxo) => ({
utxoTxId: utxo.txid,
Expand All @@ -79,26 +80,28 @@ async function btcToEvmTransfer(): Promise<void> {
publicKey: publicKeyDropedDERHeader,
depositAddress: ADDRESS as unknown as string,
domainId: DESTINATION_CHAIN_ID,
amount: AMOUNT,
amount: BigInt(AMOUNT!),
feeValue: BigInt(0),
changeAddress: ADDRESS as unknown as string,
signer: tweakedSigner,
typeOfAddress: TypeOfAddress.P2TR,
});

const transferParams: BitcoinTransferParams = {
source: SOURCE_CAIPID,
source: SOURCE_CAIPID!,
destination: DESTINATION_CHAIN_ID,
destinationAddress: DESTINATION_ADDRESS,
amount: AMOUNT,
resource: RESOURCE_ID,
destinationAddress: DESTINATION_ADDRESS!,
amount: BigInt(AMOUNT!),
resource: RESOURCE_ID!,
utxoData: mapedUtxos,
feeRate: BigInt(Math.ceil(feeRate)),
publicKey: publicKeyDropedDERHeader,
typeOfAddress: TypeOfAddress.P2TR,
network: networks.testnet,
changeAddress: ADDRESS,
size: BigInt(size),
environment: Environment.TESTNET,
sourceAddress: "",
};

const transfer = await createBitcoinFungibleTransfer(transferParams);
Expand All @@ -114,8 +117,8 @@ async function btcToEvmTransfer(): Promise<void> {
const tx = psbt.extractTransaction(true);
console.log("Transaction hex", tx.toHex());

const txId = await broadcastTransaction(tx.toHex());
const txId = await broadcastTransaction(process.env.SYGMA_ENV, tx.toHex());
console.log("Transaction broadcasted", `${EXPLORER_URL}/tx/${txId}`);
}

btcToEvmTransfer().finally(() => { });
btcToEvmTransfer().finally(() => {});
50 changes: 30 additions & 20 deletions examples/bitcoin-to-evm-fungible-transfer/src/transfer.p2wpkh.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2,17 +2,18 @@ import type { BitcoinTransferParams, UTXOData } from "@buildwithsygma/bitcoin";
import {
createBitcoinFungibleTransfer,
TypeOfAddress,
getPublicKey,
getFeeEstimates,
fetchUTXOS,
processUtxos,
broadcastTransaction,
} from "@buildwithsygma/bitcoin";
import { BIP32Factory } from "bip32";
import { mnemonicToSeed } from "bip39";
import { BIP32Factory, BIP32Interface } from "bip32";
import { initEccLib, networks } from "bitcoinjs-lib";
import dotenv from "dotenv";
import * as tinysecp from "tiny-secp256k1";

import {
calculateSize,
} from "./blockstreamApi.js";
import { broadcastTransaction, fetchUTXOS, getFeeEstimates, processUtxos } from "@buildwithsygma/utils";
import { calculateSize } from "./blockstreamApi.js";

dotenv.config();

Expand Down Expand Up @@ -49,14 +50,22 @@ async function btcToEvmTransfer(): Promise<void> {
initEccLib(tinysecp);
const bip32 = BIP32Factory(tinysecp);
console.log("Transfer BTC to EVM");
const seed = await mnemonicToSeed(MNEMONIC);
const rootKey = bip32.fromSeed(seed, networks.testnet);
const derivedNode = rootKey.derivePath(DERIVATION_PATH);

const feeRate = await getFeeEstimates('5');
const utxos = await fetchUTXOS(ADDRESS as unknown as string);
const { derivedNode } = (await getPublicKey({
bip32,
mnemonic: MNEMONIC as string,
derivationPath: DERIVATION_PATH as string,
network: networks.testnet,
typeOfAddress: TypeOfAddress.P2WPKH,
})) as { derivedNode: BIP32Interface };

const feeRate = await getFeeEstimates(process.env.SYGMA_ENV, "5");
const utxos = await fetchUTXOS(
process.env.SYGMA_ENV,
ADDRESS as unknown as string
);

const processedUtxos = processUtxos(utxos, AMOUNT);
const processedUtxos = processUtxos(utxos, Number(BigInt(AMOUNT!)));

const mapedUtxos = processedUtxos.map((utxo) => ({
utxoTxId: utxo.txid,
Expand All @@ -70,26 +79,27 @@ async function btcToEvmTransfer(): Promise<void> {
publicKey: derivedNode.publicKey,
depositAddress: ADDRESS as unknown as string,
domainId: DESTINATION_CHAIN_ID,
amount: AMOUNT,
amount: BigInt(AMOUNT!),
feeValue: BigInt(0),
changeAddress: ADDRESS as unknown as string,
signer: derivedNode,
typeOfAddress: TypeOfAddress.P2WPKH,
}); // aprox estimation of the size of the tx

const transferParams: BitcoinTransferParams = {
source: SOURCE_CAIPID,
destination: DESTINATION_CHAIN_ID,
destinationAddress: DESTINATION_ADDRESS,
amount: AMOUNT,
resource: RESOURCE_ID,
source: SOURCE_CAIPID!,
destination: DESTINATION_CHAIN_ID!,
destinationAddress: DESTINATION_ADDRESS!,
amount: BigInt(AMOUNT!),
resource: RESOURCE_ID!,
utxoData: mapedUtxos,
publicKey: derivedNode.publicKey,
typeOfAddress: TypeOfAddress.P2WPKH,
network: networks.testnet,
changeAddress: ADDRESS,
feeRate: BigInt(Math.ceil(feeRate)),
size: BigInt(size),
sourceAddress: "",
};

const transfer = await createBitcoinFungibleTransfer(transferParams);
Expand All @@ -105,8 +115,8 @@ async function btcToEvmTransfer(): Promise<void> {
const tx = psbt.extractTransaction(true);
console.log("Transaction hex", tx.toHex());

const txId = await broadcastTransaction(tx.toHex());
const txId = await broadcastTransaction(process.env.SYGMA_ENV, tx.toHex());
console.log("Transaction broadcasted", `${EXPLORER_URL}/tx/${txId}`);
}

btcToEvmTransfer().finally(() => { });
btcToEvmTransfer().finally(() => {});
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import type { Environment } from './types.js';
import type { Environment } from "@buildwithsygma/core";

declare global {
namespace NodeJS {
Expand Down
40 changes: 28 additions & 12 deletions examples/evm-to-bitcoin-fungible-transfer/src/transfer.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,8 @@
import { createEvmFungibleAssetTransfer } from "@buildwithsygma/evm";
import { Eip1193Provider } from "@buildwithsygma/core";
import {
createFungibleAssetTransfer,
FungibleTransferParams,
} from "@buildwithsygma/evm";
import dotenv from "dotenv";
import { Wallet, providers } from "ethers";
import Web3HttpProvider from "web3-providers-http";
Expand All @@ -13,42 +17,54 @@ if (!privateKey) {

const SEPOLIA_CHAIN_ID = 11155111;
const BITCOIN_DOMAIN_CAIPID = "bip122:000000000933ea01ad0ee984209779ba";
const RESOURCE_ID = "0x0000000000000000000000000000000000000000000000000000000000000700";
const SEPOLIA_RPC_URL = process.env.SEPOLIA_RPC_URL || "https://eth-sepolia-public.unifra.io"
const RESOURCE_ID =
"0x0000000000000000000000000000000000000000000000000000000000000700";
const SEPOLIA_RPC_URL =
process.env.SEPOLIA_RPC_URL || "https://eth-sepolia-public.unifra.io";
const BTC_DESTINATION_ADDRESS = process.env.BTC_DESTINATION_ADDRESS;

const explorerUrls: Record<number, string> = { [SEPOLIA_CHAIN_ID]: 'https://sepolia.etherscan.io' };
const getTxExplorerUrl = (params: { txHash: string; chainId: number }): string => `${explorerUrls[params.chainId]}/tx/${params.txHash}`;
const explorerUrls: Record<number, string> = {
[SEPOLIA_CHAIN_ID]: "https://sepolia.etherscan.io",
};
const getTxExplorerUrl = (params: {
txHash: string;
chainId: number;
}): string => `${explorerUrls[params.chainId]}/tx/${params.txHash}`;

export async function erc20Transfer(): Promise<void> {
const web3Provider = new Web3HttpProvider(SEPOLIA_RPC_URL);
const ethersWeb3Provider = new providers.Web3Provider(web3Provider);
const wallet = new Wallet(privateKey!, ethersWeb3Provider);

const params = {
const params: FungibleTransferParams = {
source: SEPOLIA_CHAIN_ID,
destination: BITCOIN_DOMAIN_CAIPID,
sourceNetworkProvider: web3Provider,
sourceNetworkProvider: web3Provider as unknown as Eip1193Provider,
resource: RESOURCE_ID,
amount: BigInt(1) * BigInt(1e8), // or any amount to send
destinationAddress: BTC_DESTINATION_ADDRESS,
recipientAddress: BTC_DESTINATION_ADDRESS!,
sourceAddress: await wallet.getAddress(),
environment: process.env.SYGMA_ENV,
};

const transfer = await createEvmFungibleAssetTransfer(params);
const transfer = await createFungibleAssetTransfer(params);

const approvals = await transfer.getApprovalTransactions();
console.log(`Approving Tokens (${approvals.length})...`);
for (const approval of approvals) {
const response = await wallet.sendTransaction(approval);
await response.wait();
console.log(`Approved, transaction: ${getTxExplorerUrl({ txHash: response.hash, chainId: SEPOLIA_CHAIN_ID })}`);
console.log(
`Approved, transaction: ${getTxExplorerUrl({ txHash: response.hash, chainId: SEPOLIA_CHAIN_ID })}`
);
}

const transferTx = await transfer.getTransferTransaction();
const response = await wallet.sendTransaction(transferTx);
await response.wait();
console.log(`Deposited, transaction: ${getTxExplorerUrl({ txHash: response.hash, chainId: SEPOLIA_CHAIN_ID })}`);
console.log(
`Deposited, transaction: ${getTxExplorerUrl({ txHash: response.hash, chainId: SEPOLIA_CHAIN_ID })}`
);
}

erc20Transfer().finally(() => { });
erc20Transfer().finally(() => {});
6 changes: 6 additions & 0 deletions examples/evm-to-evm-erc1155-transfer/.env.sample
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
PRIVATE_KEY=""
CRONOS_RPC_URL="CRONOS_RPC_URL_HERE"
SEPOLIA_RPC_URL="SEPOLIA_RPC_URL_HERE"
SYGMA_ENV="testnet"
TOKEN_ID=""
AMOUNT=""
Loading

0 comments on commit b17e54b

Please sign in to comment.