본문으로 건너뛰기

Methods

1. dapp:accounts

이 메소드는 지갑 연결을 요청하는 메소드입니다. 이 메소드를 통해 웹페이지는 지갑에 연결을 요청할 수 있고, 지갑의 사용자가 연결을 허락하면 웹페이지는 사용자의 계정에 접근할 수 있습니다. 이 메소드는 모든 체인에 대한 연결을 한 번에 요청합니다. 즉, chainNameethereum을 넣어 요청을 보낸 후 사용자의 허락을 받으면 cosmos나 다른 체인에 대해서도 연결 허락을 받은 것입니다. 웹페이지가 지갑에 이미 연결된 경우에는 사용자의 상호작용을 요구하지 않고 바로 계정의 정보를 가져옵니다.

Params

이 메소드는 가져오고 싶은 chainName값만을 인자로 받습니다.

type ChainName = 'celestia' | 'celo' | 'cosmos' | 'ethereum' | 'juno' | 'klaytn' | 'near' | 'neon' | 'solana';

window.dapp.request(chainName: ChainName, { method: "dapp:accounts" })

Returns

이 메소드는 해당 체인 계정에 대한 address값과 pubKey값을 Promise 객체로 반환합니다. 현재 WELLDONE Wallet은 체인 아이디 당 하나의 주소/퍼블릭 키 페어만 지원합니다.

{ "ethereum": { "address": "0x....", "pubKey": "0x...." } }

Example

아래 예제는 지갑에서 이더리움 체인의 계정 정보를 얻어오는 코드입니다.

라이브 에디터
결과
Loading...

2. dapp:getBalance

이 메소드는 파라미터로 받은 address의 balance를 반환하는 메소드입니다.

Params

이 메소드는 파라미터로 balance를 가져올 체인과 계정 주소를 받습니다.

type CHAIN_NAME = 'celestia' | 'celo' | 'cosmos' | 'ethereum' | 'juno' | 'klaytn' | 'near' | 'neon' | 'solana';
type ACCOUNTS = string;

const response = await window.dapp.request(CHAIN_NAME, {
method: 'dapp:getBalance',
params: [ACCOUNTS],
});

Returns

이 메소드는 인자로 전달한 계정의 잔액을 string 타입의 Promise 객체로 반환합니다.

Promise<string>;

Example

이 예제는 이더리움 계정의 balance를 가져오는 예제입니다.

라이브 에디터
결과
Loading...

3. dapp:addChain

이 메소드는 지갑에 네트워크를 추가할 수 있는 메소드입니다. 현재 Ethereum, Cosmos, Solana 기반의 체인을 추가할 수 있습니다.

WELLDONE Studio에서는 네트워크를 추가할 수 있는 메소드뿐만 아니라, 사이트를 이용해 지갑에 네트워크를 추가할 수 있도록 Add Chain을 운영하고 있습니다. 자세한 내용을 알고 싶다면 여기를 참고합니다.

Params

이 메소드는 추가할 체인의 기반이 되는 chainName값과, chainData값을 인자로 받습니다. 아래의 체인별 섹션을 통해 체인별로 params에 전달해야 하는 내용을 상세하게 알 수 있습니다.

type CHAIN_NAME = 'cosmos' | 'ethereum' | 'solana';

await window.dapp.request(chainName: ChainName, (
method: "dapp:addChain",
params: [chainData]
))

Example

Ethereum 기반의 Ubiq 네트워크를 추가해보는 예제입니다.

라이브 에디터
결과
Loading...

4. dapp:switchChain

이 메소드는 지갑이 현재 바라보고 있는 체인의 네트워크를 변경하는 메소드입니다.

Params

이 메소드는 파라미터로 네트워크를 변경할 체인의 이름 CHAIN_NAME과 변경할 네트워크의 ID NETWORK_ID 를 받습니다.

type CHAIN_NAME = 'celestia' | 'celo' | 'cosmos' | 'ethereum' | 'juno' | 'klaytn' | 'near' | 'neon' | 'solana';
type NETWORK_ID = string;

const response = await window.dapp.request(CHAIN_NAME, {
method: 'dapp:switchChain',
params: [NETWORK_ID],
});

Example

아래는 Ethereum 메인넷에서 네트워크를 Goerli 테스트넷으로 변경하는 예제 코드입니다.

라이브 에디터
결과
Loading...

5. dapp:signMessage

이 메소드는 메시지를 서명하는 메소드입니다.

Params

이 메소드는 파라미터로 체인의 이름 CHAIN_NAME과 서명하고자 하는 메시지 MESSAGE를 string 타입으로 받습니다.

type CHAIN_NAME = 'celestia' | 'celo' | 'cosmos' | 'ethereum' | 'juno' | 'klaytn' | 'near' | 'neon' | 'solana';
type MESSAGE = string;

const response = await window.dapp.request(CHAIN_NAME, {
method: 'dapp:signMessage',
params: [MESSAGE],
});

Returns

이 메소드는 트랜잭션을 서명한 결과인 signature 값과, 서명에 사용된 publicKey를 가진 객체를 Promise 배열로 반환합니다.

Promise<[{ signature: string; publicKey: string }]>;

Example

아래는 Ethereum 에서 메시지를 서명하는 예제 코드입니다. EtherscanVerify Signature 기능을 이용해서 서명이 제대로 성공했는지 확인할 수 있습니다.

라이브 에디터
결과
Loading...

6. dapp:signTransaction

이 메소드는 트랜잭션을 서명하는 메소드입니다.

Params

이 메소드는 파라미터로 체인의 이름 CHAIN_NAME과 서명하고자 하는 트랜잭션 HEX_STRING_TX_DATA 를 HEX string 타입으로 받습니다. 다양한 체인들의 트랜잭션 포맷이 상이하기 때문에 HEX string 타입을 공통으로 받아 서명을 진행하고 있습니다.

EVM 계열의 경우 트랜잭션 객체를 그대로 넣어서 전송하는 것도 가능합니다.
type CHAIN_NAME = 'celestia' | 'celo' | 'cosmos' | 'ethereum' | 'juno' | 'klaytn' | 'near' | 'neon' | 'solana';
type HEX_STRING_TX_DATA = string;

const response = await window.dapp.request(CHAIN_NAME, {
method: 'dapp:signTransaction',
params: [HEX_STRING_TX_DATA],
});

Returns

이 메소드는 트랜잭션을 서명한 결과인 signature 값과, 서명에 사용된 publicKey를 가진 객체를 Promise 배열로 반환합니다.

Promise<[{ signature: string; publicKey: string }]>;

Example

아래는 Ethereum에서 트랜잭션을 서명하는 예시입니다.

라이브 에디터
결과
Loading...

7. dapp:signAndSendTransaction

이 메소드는 트랜잭션을 서명한 후 전송하는 메소드입니다. 간단한 토큰 전송부터 컨트랙트 배포, 블록체인의 상태 변경까지 이 메소드를 통해 할 수 있습니다. 단일 트랜잭션 뿐만 아니라 여러 개의 트랜잭션 전송도 가능합니다. WELLDONE Wallet에서는 해당 지갑 주소에 연결된 네트워크를 자동으로 감지하여 가져옵니다. 따라서 트랜잭션을 보내기 이전에 메인넷에 트랜잭션을 보낼 것인지, 테스트넷에 트랜잭션을 보낼 것인지 미리 고려해두어야 합니다.

Params

파라미터로는 크게 CHAIN_NAMEHEX_STRING_TX_DATA가 있습니다. CHAIN_NAME은 연결하고자 하는 체인의 이름을, HEX_STRING_TX_DATA는 트랜잭션을 HEX string 형으로 변환한 값을 의미합니다. 다양한 체인들의 트랜잭션 포맷이 상이하기 때문에, WELLDONE Wallet에서는 트랜잭션을 HEX string 타입으로 변환한 값을 인자로 받아 트랜잭션을 전송합니다.

EVM 계열의 경우 트랜잭션 객체를 그대로 넣어서 전송하는 것도 가능합니다.
type CHAIN_NAME = 'celestia' | 'celo' | 'cosmos' | 'ethereum' | 'juno' | 'klaytn' | 'near' | 'neon' | 'solana';
type HEX_STRING_TX_DATA = 'string';

const response = await window.dapp.request(CHAIN_NAME, {
method: 'dapp:signAndSendTransaction',
params: [HEX_STRING_TX_DATA],
});

아래의 체인별 섹션을 통해 체인별로 HEX_STRING_TX_DATA에 전달해야 하는 값을 예제와 함께 상세하게 알 수 있습니다.

Returns

해당 메소드는 단일 트랜잭션 뿐만 아니라 여러 개의 트랜잭션 전송이 가능하기 때문에, 트랜잭션 해시 값을 string 타입의 Promise 배열로 반환합니다.

Promise<string[]>;

Example

아래는 이더리움 네트워크에서 트랜잭션을 보내는 예제입니다. 트랜잭션을 보내기 위해선 테스트넷 토큰이 필요합니다. 지갑 내의 FAUCET 탭에서 Ethereum Goerli 테스트넷의 faucet을 요청할 수 있습니다.

라이브 에디터
결과
Loading...