NEAR Chain Abstraction Layer (NEAR-CA)
DISCLAIMER: This should only be used for educational purposes.
NEAR-CA is a TypeScript library that provides an abstraction layer for interacting with the NEAR blockchain. It simplifies the process of performing transactions and managing accounts on NEAR and Ethereum chains.
Intended to be used on server-side applications only.
Features
- Account management for NEAR blockchain.
- Transaction signing and sending on Ethereum blockchain.
- Key derivation functions for cryptographic operations.
- Support for EIP-1559 transactions on Ethereum.
Local Testing
yarn
cp .env.example .env <---- paste your Near credentials
npx ts-node examples/opensea.ts
Installation
To install NEAR-CA, run the following command:
yarn add near-ca
Usage
For Ethereum, you can derive addresses, create payloads for transactions, and send signed transactions.
Example: Setup NearEthAdapter and Send ETH
import dotenv from "dotenv";
import { MultichainContract, NearEthAdapter, nearAccountFromEnv } from "near-ca";
dotenv.config();
const account = await nearAccountFromEnv();
const near = {
mpcContract: new MultichainContract(
account,
process.env.NEAR_MULTICHAIN_CONTRACT!
),
derivationPath: "ethereum,1",
};
const evm = {
providerUrl: process.env.NODE_URL!,
scanUrl: process.env.SCAN_URL!,
gasStationUrl: process.env.GAS_STATION_URL!,
};
const neareth = await NearEthAdapter.fromConfig({ near, evm });
await neareth.signAndSendTransaction({
receiver: "0xdeADBeeF0000000000000000000000000b00B1e5",
amount: 0.00000001,
});
Other Examples
Each of the following scripts can be run with
npx ts-node examples/*.ts
- (Basic) Send ETH
- WETH
- Transfer ERC721
- (Advanced) Buy NFT On Opensea
Configuration
Before using NEAR-CA, ensure you have the following environment variables set:
NEAR_ACCOUNT_ID
: Your NEAR account identifier.NEAR_ACCOUNT_PRIVATE_KEY
: Your NEAR account private key.NEAR_MULTICHAIN_CONTRACT
: The NEAR contract that handles multichain operations.NODE_URL=https://rpc.sepolia.org
SCAN_URL=https://sepolia.etherscan.io
GAS_STATION_URL=https://sepolia.beaconcha.in/api/v1/execution/gasnow
Copy the .env.example
file and place these values in .env