코스모스(ATOM)

코스모스 지갑 구조

코스모스의 자식주소 출금 지갑은 다음과 같이 구성되어 있습니다.

  • 대표주소
  • 자식주소

TIP
코스모스는 수수료주소를 가지지만, 사용하지는 않습니다.






자식주소 생성하기

자식주소 생성 API를 호출하여 자식주소를 생성합니다. 일반적으로 자식주소는 엔드 유저 당 1개씩 부여합니다. 생성한 자식주소는 콘솔의 [자식주소 정보]에서 확인하거나 자식주소 목록 조회 API를 호출하여 확인할 수 있습니다.

Response 예시

[
  {
    "address": "cosmos1ps8vuzj37gvtugcgsyww2m855jluzjd6wehve5",
    "name": "테스트용 자식주소"
  }
]





입금

입금 상태

외부에서 보낸 자산이 대표주소나 자식주소에 도착하면 옥텟은 이를 입금으로 인식합니다. 입금 트랜잭션이 블록에 포함되면 완료(FINALIZED)로 상태가 됩니다. 외부에서 자산을 보냈으나 대표주소나 자식주소에 도착하지 않았다면 해당 트랜잭션은 인식되지 않습니다. 따라서 입금 트랜잭션에는 실패(FAILED) 상태가 없습니다,



입금 확인

1. 콘솔에서 확인하기

콘솔의 [입출금 내역]에서 입금 내역을 확인할 수 있습니다. FINALIZED 상태인 입금은 '완료'로 표시됩니다.


2. 웹훅으로 확인하기

대표주소나 자식주소에 입금이 완료되면 입금 웹훅이 전송됩니다. 전송된 웹훅으로 입금 여부를 확인할 수 있습니다. 웹훅 이용 방법과 전송되는 데이터 형태는 웹훅 페이지를 참고하세요.






출금

출금 과정

자식주소 출금 지갑에서는 대표주소와 자식주소에서 외부로 자산을 출금합니다. 이때 출금 수수료는 출금할 주소에서 차감됩니다. 예를 들어 '자식주소 A'에서 출금 시 '자식주소 A'에서 수수료가 차감됩니다. 따라서 출금할 주소에 수수료로 지불할 자산(ATOM)을 보유하고 있어야 합니다. 출금 수수료가 부족하면 출금이 진행되지 않습니다.

  1. 출금을 요청합니다.
  2. 트랜잭션을 생성합니다.
  3. 최적 수수료를 계산한 뒤 트랜잭션을 전파합니다.
  4. 트랜잭션이 블록에 반영되면 출금이 완료됩니다.


출금 상태

트랜잭션이 블록에 포함된 즉시 출금 완료(FINALIZED) 처리됩니다.

상태명내용
PENDING출금 트랜잭션이 생성된 상태
FINALIZED출금 트랜잭션이 블록에 포함된 상태
FAILED출금 트랜잭션이 실패한 상태


출금하기

출금 신청 API를 호출하면 자식주소 또는 대표주소에서 외부로 출금을 요청할 수 있습니다. 출금 요청에 성공하면 uuid 값이 반환됩니다. 해당 값으로 출금 진행 상태를 조회할 수 있습니다.

Response 예시

{
  "uuid": "18012e3f-07f3-45ec-862b-f020c0ca935a"
}


출금 확인

1. 콘솔에서 확인하기

콘솔의 [입출금 내역]에서 출금 내역을 확인할 수 있습니다. AWAITING_WITHDRAWALPENDING 상태인 출금은 '진행'으로 표시되며, FINALIZED 상태인 출금은 '완료'로 표시됩니다.


2. API로 확인하기

출금 트랜잭션 정보 조회 API를 호출하면 특정 출금 트랜잭션의 진행 상태를 확인할 수 있습니다.

Response 예시

{
  "idx": 2289775,
  "coin": {
    "idx": 195,
    "symbol": "ATOM",
    "nameKo": "아톰",
    "nameEn": "Atom",
    "status": "ACTIVATED",
    "type": "DEFAULT",
    "contractAddress": "uatom",
    "decimals": 6,
    "createdDate": "2023-12-26T03:54:42.296Z",
    "modifiedDate": "2023-12-26T03:54:42.296Z"
  },
  "uuid": "e046710a-877d-44f2-a43f-40e08e25af56",
  "fromAddress": "cosmos1t8ddcfwyzjwqkujzcyhkm0unhq5qyfag9mtd4z",
  "toAddress": "cosmos1fqrx3dvk2xwg9jqsurpnu477f5mues40mz8myv",
  "amount": "0.10000000000000000000",
  "memo": null,
  "requestId": "20231229T162800",
  "type": "API",
  "description": "",
  "requiredApprovalCount": 1,
  "useApiAutoApproval": false,
  "useFeeDelegation": false,
  "feePayerAddress": null,
  "status": "SENT",
  "createdDate": "2023-12-29T06:28:50.012Z",
  "modifiedDate": "2023-12-29T06:30:08.000Z",
  "rejectedDate": null,
  "transaction": {
    "idx": 317057,
    "uuid": "e046710a-877d-44f2-a43f-40e08e25af56",
    "type": "WITHDRAWAL",
    "txid": "98C02770BDE1F0BA1FE83329AFDBFE88503A968DE501C9CB5F8FAD4309C41A0A",
    "fromAddress": "cosmos1t8ddcfwyzjwqkujzcyhkm0unhq5qyfag9mtd4z",
    "toAddress": "cosmos1fqrx3dvk2xwg9jqsurpnu477f5mues40mz8myv",
    "amount": "0.10000000000000000000",
    "usedFee": "0.00050000000000000000",
    "nonce": 5,
    "blockHeight": null,
    "serialized": "0a92010a8f010a1c2f636f736d6f732e62616e6b2e763162657461312e4d736753656e64126f0a2d636f736d6f733174386464636677797a6a77716b756a7a6379686b6d30756e6871357179666167396d7464347a122d636f736d6f7331667172783364766b32787767396a71737572706e7534373766356d75657334306d7a386d79761a0f0a057561746f6d120631303030303012660a500a460a1f2f636f736d6f732e63727970746f2e736563703235366b312e5075624b657912230a2103bfb187b6e375854ea7705e4813cdf22ac1d1859b7e5662d8edcb95bf683e710512040a020801180512120a0c0a057561746f6d120335303010a08d061a401fa868fd46daf9d17d0bf519473fa436a855d00954a2ad6b49e44527bbbd07635682a207ebd6d1b9a595b87dae3f22f9c41c5a4f3b8d02724ab3bc93610de7f6",
    "memo": null,
    "status": "PENDING",
    "outputIndex": 0,
    "createdDate": "2023-12-29T06:30:08.369Z",
    "modifiedDate": "2023-12-29T06:30:08.369Z",
    "unfinalizedDate": null,
    "finalizedDate": null,
    "failedDate": null
  },
  "errorCode": null,
  "errorMessage": null
}

3. 웹훅으로 확인하기

대표주소에서 외부로 출금이 완료되면 출금 웹훅이 전송됩니다. 전송된 웹훅으로 출금 여부를 확인할 수 있습니다. 웹훅 이용 방법과 전송되는 데이터 형태는 웹훅 페이지를 참고하세요.






수수료

트랜잭션에 사용된 수수료는 가스 사용량의 최댓값과 가스 단가를 곱하여 계산합니다.

트랜잭션 수수료 = Gas Wanted x Gas Price
  • Gas Wanted는 가스 사용량의 최댓값입니다. 실제 가스 사용량은 이보다 더 적습니다. 하지만 실제 사용량과 상관없이 Gas wanted 값만큼을 수수료를 지불하게 됩니다.
  • Gas Price는 가스 단가입니다.





Faucet

테스트넷일 경우 코스모스 디스코드에서 테스트용 ATOM을 얻은 뒤 입금해야 합니다. 테스트넷에 실제 ATOM을 입금하면 입금이 인식되지 않습니다.