리플(XRP)
리플 지갑 구조
리플의 중앙화 지갑은 다음과 같이 구성되어 있습니다.
- 대표주소
리플은 자식주소를 생성하지 않기 때문에 엔드 유저가 대표주소로 바로 입금합니다. 이때, 각 엔드 유저의 입금 내역을 구분하기 위해 엔드 유저에게 destination tag를 부여합니다. 엔드 유저는 대표주소로 입금을 진행할 때 destination tag를 입력해야 합니다.
주소
리플은 주소를 활성화하기 위해 10 XRP을 입금해야 합니다. 옥텟에서 리플 주소가 조회되더라도, API를 호출할 경우 에러가 반환됩니다.
입금
입금 상태
외부에서 보낸 자산이 대표주소에 도착하면 옥텟은 이를 입금으로 인식합니다. 외부에서 자산을 보냈으나 대표주소에 도착하지 않았다면 해당 트랜잭션은 인식되지 않습니다. 따라서 입금 트랜잭션에는 실패(FAILED
) 상태가 없습니다.
상태명 | 내용 |
---|---|
FINALIZED | 입금이 완료된 상태 |
입금 확인
1. 콘솔에서 확인하기
콘솔의 [입출금 내역]에서 입금 내역을 확인할 수 있습니다. FINALIZED
상태인 입금은 '완료'로 표시됩니다.
2. 웹훅으로 확인하기
대표주소에 입금이 완료되면 입금 웹훅이 전송됩니다. 전송된 웹훅으로 입금 여부를 확인할 수 있습니다. 웹훅 이용 방법과 전송되는 데이터 형태는 웹훅 페이지를 참고하세요.
출금
출금 과정
대표주소에서 외부로 자산을 출금할 수 있습니다.
- 출금을 요청합니다.
- 트랜잭션을 생성합니다.
- 최적 수수료를 계산한 뒤 트랜잭션을 전파합니다.
- 트랜잭션이 블록에 반영되면 출금이 완료됩니다.
출금 상태
트랜잭션이 블록에 포함된 즉시 출금 완료(FINALIZED
) 처리됩니다.
상태명 | 내용 |
---|---|
AWAITING_DECISION | 출금 승인 대기 중인 상태 |
REJECTED | 출금이 거절된 상태 |
AWAITING_WITHDRAWAL | 출금이 승인되어 출금 대기 중인 상태 |
PENDING | 출금 트랜잭션이 생성된 상태 |
FINALIZED | 출금 트랜잭션이 블록에 포함된 상태 |
FAILED | 출금 트랜잭션이 실패한 상태 |
출금하기
출금 신청 API를 호출하면 대표주소에서 외부로 출금을 요청할 수 있습니다. 출금 요청에 성공하면 uuid
값이 반환됩니다. 해당 값으로 출금 진행 상태를 조회할 수 있습니다.
Response 예시
{
"uuid": "8bc699a0-7dbd-4b34-b546-e908b448907d"
}
출금 확인
1. 콘솔에서 확인하기
콘솔의 [입출금 내역]에서 출금 내역을 확인할 수 있습니다. AWAITING_WITHDRAWAL
와 PENDING
상태인 출금은 '진행'으로 표시되며, FINALIZED
상태인 출금은 '완료'로 표시됩니다.
2. API로 확인하기
출금 트랜잭션 정보 조회 API를 호출하면 특정 출금 트랜잭션의 진행 상태를 확인할 수 있습니다.
Response 예시
{
"idx": 242657,
"uuid": "d47e020f-87e7-4993-90a8-6a2256c0c29b",
"type": "WITHDRAWAL",
"txid": "73C62412959455C1D86AABCBBFA022C0B5FCCB313D44165A1AD56A8434C2770E",
"fromAddress": "rajTiWSStKNU6ZuAtKrEsiqh11NgjhMYzw",
"toAddress": "rppmpPCLPcvBsXtRSHr6uKEw87rQdFaunH",
"amount": "1.00000000000000000000",
"usedFee": "0.00100000000000000000",
"nonce": null,
"blockHeight": "35807818",
"serialized": "12000022000000002402219FCF201B0222625B6140000000000F42406840000000000003E8732103A0A29F10A42C163999C7C0A579937D62EB39B5DCF267B1D4A38C7C96387A023274473045022100E9175A0CB20D2A69A1546AD5ADCD32B04FCCB5792E5F2EBD0207666D3798AF7F0220150BA3E1EDCCB06492D45F112E3D51BD3DB13D2CAE94BF8E400E64452571165D81143EE083FB424D1F78352B71F17982D02A2EE5E5B783140B4D4A8647BF7A9F5335F5D6E8869406AC2E51E7",
"memo": "",
"status": "FINALIZED",
"outputIndex": 0,
"createdDate": "2023-03-02T03:34:28.627Z",
"modifiedDate": "2023-03-02T03:34:30.924Z",
"unfinalizedDate": "2023-03-02T03:34:31.000Z",
"finalizedDate": "2023-03-02T03:34:31.000Z",
"failedDate": null,
"coin": {
"idx": 13,
"symbol": "XRP",
"nameKo": "리플",
"nameEn": "Ripple",
"status": "ACTIVATED",
"type": "DEFAULT",
"contractAddress": null,
"decimals": 6,
"createdDate": "2023-02-20T11:55:08.000Z",
"modifiedDate": "2023-02-27T01:06:50.033Z"
}
}
3. 웹훅으로 확인하기
대표주소에서 외부로 출금이 완료되면 출금 웹훅이 전송됩니다. 전송된 웹훅으로 출금 여부를 확인할 수 있습니다. 웹훅 이용 방법과 전송되는 데이터 형태는 웹훅 페이지를 참고하세요.
잔액 조회 기준
주소 잔액 조회 API를 호출하면 특정 주소에 보관된 자산의 잔액을 확인할 수 있습니다. 이때 조회되는 잔액은 총 잔액(Total Balance)과 사용 가능 잔액(Liquid Balance)으로 나누어집니다.
- 총 잔액은 confirmation이 1 이상인 모든 자산을 의미합니다.
- 사용 가능 잔액은 출금 가능한 자산을 의미합니다.
수수료
리플 트랜잭션 수수료는 0.0001 XRP입니다.
Faucet
테스트넷일 경우 Faucet 사이트에서 테스트용 XRP를 얻은 뒤 입금해야 합니다. 테스트넷에 실제 XRP를 입금하면 입금이 인식되지 않습니다.
Updated about 1 year ago