XRPL Docs (Korean)
  • XRPL Docs(Kor)
  • Introduction
    • XRP Ledger란?
    • XRP란?
    • Crypto Wallets
    • Transactions and Requests
    • Software Ecosystem
  • Use Cases
    • 결제(Payments)
      • P2P 결제(Peer-to-Peer Payments)
      • 예금 제한(Restricting Deposits)
      • 스마트 컨트랙트(Smart Contracts)
    • 토큰화(Tokenization)
      • 스테이블코인 발행인(Stablecoin Issuer)
      • NFT 마켓플레이스 개요(NFT Marketplace Overview)
    • 탈중앙화 금융(Decentralized Finance)
      • 알고리즘 트레이딩(Algorithmic Trading)
      • 거래소에 XRP 상장하기((List XRP as an Exchange)
  • Concepts
    • 소개
      • 컨센서스 소개
      • XRP
      • 소프트웨어 생태계
    • XRP Ledger 서버
      • rippled 서버 모드(rippled Server Modes)
      • 클러스터링(Clustering)
      • Ledger 역사
      • 피어 프로토콜(Peer Protocol)
      • 트랜잭션 검열 감지(Transaction Censorship Detection)
      • 병렬 네트워크(Parallel Networks)
      • 수정안(Amendments)
        • XRP Ledger에 코드를 기여하는 방법
        • 알려진 수정안
      • 클리오 서버(The Clio Server)
    • 컨센서스 네트워크(Consensus Protocol)
      • 컨센서스 구조(Consensus Structure)
      • 컨센서스 원칙과 규칙(Consensus Principles and Rules)
      • 공격과 실패 모드에 대한 컨센서스 보호(Consensus Protections Against Attacks and Failure Modes)
      • 불변성 체크
      • 부정 UNL
      • 트랜잭션 취소 정보
      • 트랜잭션 변조 가능성
      • 수수료 투표
      • 컨센서스 연구
    • Ledgers
      • Ledger 구조(Ledger Structure)
      • 개방형, 폐쇄형, 검증형 Ledgers(Open, Closed, and Validated Ledgers)
      • Ledger 마감 시간(Ledger Close Times)
    • 트랜잭션(Transactions)
      • 수수료(Fees)
      • 신뢰할 수 있는 트랜잭션 제출(Reliable Transaction Submission)
      • 보안 서명(Secure Signing)
      • 출발, 데스티네이션 태그(Source and Destination Tags)
      • 트랜잭션 비용(Transaction Cost)
      • 트랜잭션 대기열(Transaction Queue)
      • 결과의 불변성(Finality of Results)
        • 트랜잭션 결과 조회(Look Up Transaction Results)
        • Transaction Malleability
    • 결제 유형
      • XRP 직접 결제
      • 교차 화폐 결제
      • 수표
      • 에스크로
      • 부분 결제
      • 결제 채널
    • 토큰(Tokens)
      • Non-Fungible Tokens
        • NFT 정보 저장소(NFT Payload Storage)
        • XRP Ledger에서 NFT 토큰 거래(Trading NFTokens on the XRP Ledger)
        • NFT Reserve Requirements
        • 일괄 발행(Batch minting)
        • 다른 계정에게 NFT 발행 권한 부여(Authorizing Another Account to Mint Your NFTs)
        • NFT 경매 진행하기(Running an NFT Auction)
        • NFT를 컬렉션으로 발행하기(Minting NFTs into Collections)
        • NFT의 고정 공급 보장하기(Guaranteeing a Fixed Supply of NFTs)
        • NFT 관련 API(NFT APIs)
      • 신뢰선과 발급(Trust Lines and Issuing)
      • 승인된 신뢰선(Authorized Trust Lines)
      • 토큰 환수(Clawing Back Tokens)
      • Freezing Tokens(토큰 동결)
        • 동결에 대한 일반적인 오해(Common Misunderstandings about Freezes )
      • Rippling
      • 이체 수수료(Transfer Fees)
      • 경로(Paths)
      • Demurrage(과잉보유비용)
      • 탈중앙화 거래소(Decentralized Exchange)
        • 제안(Offers)
        • Auto-Bridging
        • Tick Size
        • AMM(Automated Market Makers)
    • 계정
      • 다중 서명
      • 티켓
      • 계정 유형
      • 계정 삭제
      • 준비금(Reserves)
      • 주소(Addresses)
      • 암호화 키(Cryptographic Keys)
      • 입금 승인(Deposit Authorization)
  • Tutorials
    • 퍼블릭 서버(Public Servers)
    • Python
      • Python으로 시작하기(Get Started Using Python)
      • python 모듈형 튜토리얼(Modular Tutorials in Python)
        • python을 이용한 Send Payments(Send Payments Using Python)
          • 계정 생성 및 XRP 전송(Create Accounts and Send XRP Using Python)
          • 신뢰 생성 및 Currency 전송 (Create Trust Line and Send Currency Using Python)
          • 시간 보류 에스크로 생성(Create Time-based Escrows Using Python)
        • python을 이용한 NFTs(NFTs Using Python)
          • NFTs 발행과 소각(Mint and Burn NFTs Using Python)
          • NFTs 전송 (Transfer NFTs Using Python)
          • NFT 판매 중개 (Broker an NFT Sale Using Python)
          • 공인 발행인 지정 (Assign an Authorized Minter Using Python)
          • NFTs 일괄 발행 (Batch Mint NFTs Using Python)
        • Python에서 데스크톱 지갑 구축(Build a Desktop Wallet in Python)
    • JavaScript
      • JavaScript로 시작하기(Get Started Using JavaScript)
      • JavaScript 모듈형 튜토리얼(Modular Tutorials in JavaScript)
        • JavaScript를 이용한 Send Payments(Send Payments Using JavaScript)
          • JavaScript를 이용한 계정 생성 및 XRP 전송(Create Accounts and Send XRP Using JavaScript)
          • JavaScript를 이용한 신뢰선 생성 및 화폐 전송(Create Trust Line and Send Currency Using JavaScript)
          • 시간 기반 에스크로 생성하기(Create Time-based Escrows Using JavaScript)
          • 조건부 에스크로 생성하기(Create Conditional Escrows Using JavaScript)
        • JavaScript를 이용한 NFTs(NFTs Using JavaScript)
          • JavaScript를 이용한 NFTs 발행 및 소각(Mint and Burn NFTs Using JavaScript)
          • JavaScript를 이용한 NFTs 전송(Transfer NFTs Using JavaScript)
          • JavaScript를 이용한 NFT 판매 중개(Broker an NFT Sale Using JavaScript)
          • JavaScript를 이용한 공인 발행인 지정(Assign an Authorized Minter Using JavaScript)
          • JavaScript를 이용한 NFTs 일괄 발행(Batch Mint NFTs Using JavaScript)
      • JavaScript를 이용한 브라우저 지갑 개발(Build a Browser Wallet in JavaScript)
      • JavaScript를 이용한 데스크탑 지갑 개발(Build a Desktop Wallet in JavaScript)
    • Java
      • Java로 시작하기(Get Started Using Java)
    • HTTP / Websocket APIs
      • HTTP/WebSocket API 사용 시작하기(Get Started Using HTTP / WebSocket APIs)
      • WebSocket으로 수신 결제 모니터링(Monitor Incoming Payments with WebSocket)
    • Tasks
      • 계정 설정 관리(Manage Account Settings)
        • 일반 키 쌍 할당
        • 일반 키 쌍 변경 또는 제거
        • 마스터 키 쌍 비활성화
        • 다중 서명 설정
        • 다중 서명 트랜잭션 전송
        • 데스티네이션 태그 필요
        • 오프라인 계정 설정 튜토리얼
        • 티켓 사용(Use Tickets)
      • XRP 보내기(Send XRP)
      • 특수 결제 유형 사용(Use Specialized Payment Types)
        • 에스크로 사용(Use escrow)
          • 시간 보류 에스크로 보내기(Send a Time-Held Escrow)
          • 조건부 보류 에스크로 보내기(Send a Conditionally-Held Escrow)
          • 만료된 에스크로 취소(Cancel an Expired Escrow)
          • 에스크로 조회(Look up Escrows)
          • 에스크로를 스마트 컨트랙트로 사용(Use an Escrow as a Smart Contract)
        • 결제 채널 사용(Use Payment Channels)
          • 결제 채널을 열어 거래소 간 네트워크 활성화(Open a Payment Channel to Enable an Inter-Exchange Network)
        • 수표 사용(Use Checks)
          • 수표 전송(Send a Check)
          • 정확한 금액의 수표 현금화(Cash a Check for an Exact Amount)
          • 유연한 금액의 수표 현금화(Cash a Check for a Flexible Amount)
          • 수표 취소(Cancel a Check)
          • 발신자별 수표 조회(Look Up Checks by Sender)
          • 수취인별 수표 조회(Look Up Checks by Recipient)
      • 토큰 사용(Use Tokens)
        • 대체가능한 토큰 발행(Issue a Fungible Token)
        • 탈중앙화 거래소에서 거래(Trade in the Decentralized Exchange)
        • 동결 금지 활성화
        • 글로벌 동결 시행
        • 신뢰선 동결하기
    • Apps 구축
      • JS에서 데스크톱 지갑 구축
      • JS에서 브라우저 지갑 구축
    • XRP Ledger 비즈니스
      • XRP 차트에 거래소 등록하기
      • 스테이블코인 발행자 되기
    • rippled 서버 관리
      • rippled 설치
        • 시스템 요구 사항
        • CentOS/Red Hat에 yum으로 설치하기
        • 우분투 또는 데비안 리눅스에 설치
        • 리눅스에서 자동 업데이트
        • CentOS/Red Hat에서 수동 업데이트
        • 우분투 또는 데비안에서 수동 업데이트
        • 리포팅 모드에서 rippled 빌드 및 실행
        • 용량 계획
        • rippled v1.3.x 마이그레이션 지침
      • rippled 구성
        • rippled를 검증인으로 실행하기
        • rippled를 스톡 서버로 실행
        • 수정안 투표 구성
        • 수정안 테스트
        • StatsD 구성
        • rippled를 병렬 네트워크에 연결하기
        • 온라인 삭제 구성
        • 권고 삭제 구성
        • 히스토리 샤딩 구성
        • 전체 히스토리 구성
        • gRPC 구성
        • 공개 서명 사용
      • 피어링 구성
        • 클러스터 rippled 서버
        • 비공개 서버 구성
        • 피어 크롤러 구성
        • 링크 압축 사용
        • 피어링을 위한 포트 포워드
        • 특정 피어에 수동으로 연결
        • 최대 피어 수 설정
        • 피어 예약 사용
      • stand-alone 모드에서 rippled 기능 테스트하기
        • stand-alone 모드에서 새 제네시스 ledger 시작하기
        • stand-alone 모드에서 저장된 ledger 불러오기
        • stand-alone 모드에서 ledger 진행하기
      • 문제 해결
        • rippled 문제 진단하기
        • 상태 확인 개입
        • 로그 메시지 이해
        • rippled 서버가 동기화되지 않음
        • rippled 서버가 수정이 차단됨
        • rippled 서버가 시작되지 않음
        • SQLite 트랜잭션 데이터베이스 페이지 크기 문제 해결
    • 클리오 서버 관리
      • 우분투 리눅스에 클리오 설치
  • References
    • XRP Ledger 프로토콜 참조(XRP Ledger Protocol Reference)
      • 기본 데이터 유형(Basic Data Types)
        • base58 인코딩(base58 Encodings)
        • 화폐 형식(Currency Formats)
        • NFToken
      • Ledger 데이터 형식(Ledger Data Formats)
        • Ledger 헤더(Ledger Header)
        • Ledger 객체 IDs
        • Ledger 객체 유형
          • AccountRoot
          • Amendments
          • AMM(experimental - 수정중)
          • Check
          • DepositPreauth
          • DirectoryNode
          • Escrow
          • FeeSettings
          • LedgerHashes
          • NegativeUNL
          • NFTokenOffer
          • NFTokenPage
          • Offer
          • PayChannel
          • RippleState
          • SignerList
          • Ticket
      • 트랜잭션 참조(Transaction Reference)
        • 트랜잭션 공통 필드(Transaction Common Fields)
        • 트랜잭션 유형(Transaction Types)
          • AccountSet
          • AccountDelete
          • AMMBid
          • AMMCreate
          • AMMDelete
          • AMMDeposit
          • CheckCancel
          • CheckCash
          • CheckCreate
          • DepositPreauth
          • EscrowCancel
          • EscrowCreate
          • EscrowFinish
          • NFTokenAcceptOffer
          • NFTokenBurn
          • NFTokenCancelOffer
          • NFTokenCreateOffer
          • NFTokenMint
          • OfferCancel
          • OfferCreate
          • Payment
          • PaymentChannelClaim
          • PaymentChannelCreate
          • PaymentChannelFund
          • SetRegularKey
          • SignerListSet
          • TicketCreate
          • TrustSet
        • Pseudo-Transactions
          • EnableAmendment
          • SetFee
          • UNLModify
        • 트랜잭션 결과(Transaction Results)
          • tec Codes
          • tef Codes
          • tel Codes
          • tem Codes
          • ter Codes
          • tes Success
        • 트랜잭션 메타데이터(Transaction Metadata)
      • Binary Format
    • 클라이언트 라이브러리
      • JavaScript / TypeScript 클라이언트 라이브러
        • ripple-lib 1.x에서 xrpl.js 2.x로의 마이그레이션 가이드
      • Python 클라이언트 라이브러리
      • Java 클라이언트 라이브러리
      • Ruby 클라이언트 라이브러리
    • HTTP / WebSocket APIs
      • API 규칙
        • 요청 형식
        • 응답 형식
        • 오류 형식
        • 마커 및 페이지네이션
        • 속도 제한
        • rippled 서버 상태
      • 공개 API 메소드
        • 계정 메소드
          • account_channels
          • account_currencies
          • account_info
          • account_lines
          • account_nfts
          • account_objects
          • account_offers
          • account_tx
          • gateway_balances
          • noripple_check
        • Ledger 메소드
          • ledger
          • ledger_closed
          • ledger_current
          • ledger_data
          • ledger_entry
        • 트랜잭션 메소드
          • submit
          • submit_multisigned
          • transaction_entry
          • tx
          • tx_history
        • 경로와 오더북 메소드
          • book_offers
          • deposit_authorized
          • nft_buy_offers
          • nft_sell_offers
          • path_find
          • ripple_path_find
        • 결제 채널 메소드
          • channel_authorize
          • channel_verify
        • 구독 메소드
          • 구독
          • 구독 취소
        • Server Info 메소드
          • fee
          • manifest
          • server_info (rippled)
          • server_state
        • 클리오 서버
          • server_info
          • ledger
          • nft_history
          • nft_info
        • 유틸리티 메소드
          • json
          • ping
          • random
      • 관리자 API 메소드
        • 키 생성 방법
          • validation_create
          • wallet_propose
        • 로깅 및 데이터 관리 메소드
          • can_delete
          • crawl_shards
          • download_shard
          • ledger_cleaner
          • ledger_request
          • log_level
          • logrotate
          • node_to_shard
        • 서버 컨트롤 메소드
          • ledger_accept
          • stop
          • validation_seed
        • 서명 메소드
          • sign
          • sign_for
        • 피어 관리 메소드
          • connect
          • peer_reservations_add
          • peer_reservations_del
          • peer_reservations_list
          • peers
        • 상태 및 디버깅 메소드
          • consensus_info
          • feature
          • fetch_info
          • get_counts
          • print
          • validator_info
          • validators
        • rippled 커맨드라인 사용 참조
        • 피어 포트 메소드
          • 상태 확인
          • 피어 크롤러
          • 유효성 검증인 목록 메소드
    • xrp-ledger.toml File
  • Infrastructure
    • 커맨드 라인 사용법(Commandline Usage)
    • Install rippled
      • System Requirements
      • Install on CentOS/RedHat with yum
      • Install on Ubuntu or Debian Linux
      • Update Automatically on Linux
      • Update Manually on CentOS/Red Hat
      • Update Manually on Ubuntu or Debian
      • Build and Run rippled in Reporting Mode
      • Capacity Planning
    • Configure rippled
      • Server Modes
        • Run rippled as a Validator
        • Run rippled as a Stock Server
      • Data Retention
        • Configure Full History
        • 온라인 삭제(Online Deletion)
        • Configure Online Deletion
        • Configure Advisory Deletion
        • 히스토리 샤딩(History Sharding)
        • Configure History Sharding
      • Configure Amendment Voting
      • Test Amendments
      • Configure StatsD
      • Connect Your rippled to a Parallel Network
      • Configure gRPC
      • Enable Public Signing
    • Peering
      • Cluster rippled Servers
      • Configure a Private Server
      • Configure the Peer Crawler
      • Enable Link Compression
      • Forward Ports for Peering
      • Manually Connect to a Specific Peer
      • Set Maximum Number of Peers
      • Use a Peer Reservation
    • Testing and Auditing
      • Start a New Genesis Ledger in Stand-Alone Mode
      • Load a Saved Ledger in Stand-Alone Mode
      • Advance the Ledger in Stand-Alone Mode
    • Troubleshooting
      • Diagnosing Problems with rippled
      • Health Check Interventions
      • Understanding Log Messages
      • rippled Server Doesn't Sync
      • rippled Server is Amendment Blocked
      • rippled Server Won't Start
    • Install Clio on Ubuntu Linux
    • Run a Private Network with Docker
Powered by GitBook
On this page
  • 결제 JSON 예시
  • 결제 필드
  • 결제 유형
  • SendMax 및 금액에 대한 특수 발행자 값
  • 계정 만들기
  • 경로
  • 결제 플래그
  • 부분 결제
  • 품질 제한
  1. References
  2. XRP Ledger 프로토콜 참조(XRP Ledger Protocol Reference)
  3. 트랜잭션 참조(Transaction Reference)
  4. 트랜잭션 유형(Transaction Types)

Payment

결제 트랜잭션은 한 계정에서 다른 계정으로 가치가 이전되는 것을 의미합니다. (이동 경로에 따라 원자 단위로 발생하는 추가적인 가치 교환이 포함될 수 있습니다.) 이 거래 유형은 여러 유형의 결제에 사용할 수 있습니다.

결제는 계정을 만드는 유일한 방법이기도 합니다.

결제 JSON 예시

{
  "TransactionType" : "Payment",
  "Account" : "rf1BiGeXwwQoi8Z2ueFYTEXSwuJYfV2Jpn",
  "Destination" : "ra5nK24KXen9AHvsdFTKHSANinZseWnPcX",
  "Amount" : {
     "currency" : "USD",
     "value" : "1",
     "issuer" : "rf1BiGeXwwQoi8Z2ueFYTEXSwuJYfV2Jpn"
  },
  "Fee": "12",
  "Flags": 2147483648,
  "Sequence": 2,
}

결제 필드

결제 거래에는 공통 필드 외에도 다음 필드가 사용됩니다:

필드

JSON 유형

설명

Amount

금액

전달할 통화 금액입니다. XRP가 아닌 금액의 경우 중첩된 필드 이름은 반드시 소문자여야 합니다. tfPartialPayment 플래그가 설정되어 있으면 대신 이 금액까지만 전달합니다.

Destination

문자열

계정 ID

결제를 받을 계정의 고유 주소입니다.

DestinationTag

숫자

UInt32

(선택 사항) 목적지 또는 결제할 호스팅된 수취인에게 지급하는 이유를 식별하는 임의의 태그입니다.

InvoiceID

문자열

해시256

(선택 사항) 이 결제의 특정 이유 또는 식별자를 나타내는 임의의 256비트 해시입니다.

Paths

경로 배열의 배열

경로 집합

(선택 사항, 자동 채우기 가능) 이 거래에 사용할 결제 경로의 배열입니다. XRP 간 트랜잭션의 경우 생략해야 합니다.

SendMax

금액

(선택 사항) 송금 수수료, 환율, 슬리피지를 포함하여 이 거래에 허용되는 소스 통화의 최대 금액입니다. 트랜잭션 제출 비용으로 소멸된 XRP는 포함되지 않습니다. XRP가 아닌 금액의 경우 중첩된 필드 이름은 반드시 소문자여야 합니다. 교차 통화/교차 발행 결제의 경우 반드시 입력해야 합니다. XRP 간 결제의 경우 생략해야 합니다.

DeliverMin

금액

(선택 사항) 이 트랜잭션이 전달해야 하는 목적지 통화의 최소 금액입니다. 부분 결제인 경우에만 유효합니다. XRP가 아닌 금액의 경우 중첩된 필드 이름은 소문자입니다.

결제 유형

결제 트랜잭션 유형은 여러 가지 유형의 추상 작업을 나타낼 수 있는 범용 도구입니다. 아래 표에 설명된 대로 트랜잭션의 필드를 기준으로 트랜잭션 유형을 식별할 수 있습니다:

지불 유형

Amount

SendMax

Paths

Address= Destination?

설명

문자열(XRP)

생략

생략

아니요

XRP에서 XRP로 직접 결제 문자열(XRP) 생략 생략 없음 한 계정에서 다른 계정으로 XRP를 직접 이체하지 않습니다. 항상 정확한 금액을 전달합니다. 기본 거래 비용 외에는 수수료가 적용되지 않습니다.

객체

객체(선택사항)

선택 과목

아니요

XRP Ledger에 추적된 비XRP 통화 또는 자산의 금액을 늘리거나 줄입니다. 직접 송금 및 상환 시에는 송금 수수료와 동결이 적용되지 않습니다.

객체(비XRP) / 문자열(XRP)

객체(비XRP) / 문자열(XRP)

일반적으로 필수

아니요

한 홀더에서 다른 홀더로 토큰을 전송할 수 없습니다. 금액 또는 SendMax는 XRP 또는 토큰일 수 있지만 둘 다 XRP일 수는 없습니다. 이러한 결제는 발행자를 통해 파급되며, 트랜잭션에 경로 세트가 지정되어 있는 경우 여러 중개자를 통해 더 긴 경로를 거칠 수 있습니다. 이러한 유형의 거래에는 발행자가 설정한 이체 수수료가 적용됩니다. 이러한 트랜잭션은 탈중앙화 거래소에서 오퍼를 사용해 서로 다른 통화 간 또는 통화 코드가 같고 발행자가 다른 통화 간에 연결합니다.

객체(비XRP) / 문자열(XRP)

객체(비XRP) / 문자열(XRP)

일반적으로 필수

아니요

모든 통화로 전송합니다. tfPartialPayment 플래그를 사용합니다. 트랜잭션이 성공하기 위해 송금해야 하는 최소 금액을 지정하는 DeliverMin 금액을 포함할 수 있으며, 트랜잭션에 DeliverMin이 지정되지 않은 경우 양수 금액을 송금해도 성공할 수 있습니다.

통화 변환

객체(비XRP) / 문자열(XRP)

객체(비XRP) / 문자열(XRP)

필수

예

탈중앙화 거래소에서 오퍼를 소비하여 한 통화를 다른 통화로 변환하여 차익거래 기회를 잡을 수 있습니다. 금액과 SendMax는 모두 XRP일 수 없습니다. 송금인에게 돈을 전달하기 때문에 순환 결제라고도 합니다. 데이터 API는 이러한 유형의 거래를 '결제'가 아닌 '교환'으로 추적합니다.

SendMax 및 금액에 대한 특수 발행자 값

대부분의 경우, XRP가 아닌 화폐 금액의 발행자 필드는 토큰의 발행자를 나타냅니다. 그러나 결제를 설명할 때는 결제의 금액과 SendMax 필드에 있는 발행자 필드에 특별한 규칙이 있습니다.

  • 동일한 화폐 코드에 대해 두 주소 간에는 잔액이 하나만 있을 수 있습니다. 즉, 금액의 발행자 필드가 토큰을 발행한 주소가 아닌 트랜잭션 상대방을 가리키는 경우가 있습니다.

  • 목적지 금액 필드의 발행자 필드가 목적지 주소와 일치하면 "목적지가 수락하는 모든 발행자"를 의미하는 특수한 경우로 취급됩니다. 여기에는 대상 주소에 양수 한도의 신뢰선이 있는 모든 주소와 대상 주소에서 발행한 화폐 코드가 동일한 토큰이 포함됩니다.

  • SendMax 필드의 발행자 필드가 소스 계정의 주소와 일치하면 "소스가 사용할 수 있는 모든 발행자"를 의미하는 특수한 경우로 취급됩니다. 여기에는 다른 계정이 소스 계정으로 확장한 신뢰선에 새 토큰을 만들고 소스 계정이 다른 발행자로부터 보유한 토큰을 전송하는 것이 포함됩니다.

계정 만들기

결제 트랜잭션 유형은 자금이 입금되지 않은 주소로 충분한 XRP를 송금하여 XRP Ledger에 새 계정을 만들 수 있습니다. 미송금 주소로의 다른 트랜잭션은 항상 실패합니다.

자세한 내용은 계정을 참조하세요.

경로

경로가 있는 경우, 경로 필드에는 경로 집합(경로 배열)이 포함되어야 합니다. 각 개별 경로는 다양한 중개 계정과 오더북을 통해 발신자에서 수신자로 값이 이동할 수 있는 한 가지 방법을 나타냅니다. 예를 들어 최적의 환율을 얻기 위해 여러 개의 오더북을 사용하여 화폐를 교환하는 경우처럼 단일 트랜잭션에 여러 경로를 사용할 수 있습니다.

다음을 포함한 직접 결제의 경우 경로 필드를 생략해야 합니다:

  • XRP에서 XRP로 이체.

  • 발신자와 수신자를 연결하는 신뢰선을 통한 직접 이체.

경로 필드를 제공하면 서버는 트랜잭션 처리 시점에 제공된 세트와 기본 경로(지정된 계정을 연결하는 가장 직접적인 방법) 중에서 사용할 경로를 결정합니다. 이 결정은 결정론적이며 비용을 최소화하려고 시도하지만 완벽하다고 보장할 수는 없습니다.

Paths 필드는 빈 배열이 아니어야 하며, 멤버가 모두 빈 배열인 배열도 아니어야 합니다.

자세한 내용은 경로를 참조하십시오.

결제 플래그

결제 유형의 트랜잭션은 다음과 같이 플래그 필드에 추가 값을 지원합니다:

플래그 이름

16진수 값

소수점 값

설명

tfNoDirectRipple

0x00010000

65536

기본 경로를 사용하지 말고 경로 필드에 포함된 경로만 사용하세요. 이는 거래가 차익거래 기회를 갖도록 강제하기 위한 것입니다. 대부분의 고객은 필요하지 않습니다.

tfPartialPayment

0x00020000

131072

지정된 금액을 SendMax보다 많이 쓰지 않고도 송금할 수 없는 경우 완전히 실패하지 않고 수신 금액을 줄입니다. 자세한 내용은 부분 결제를 참조하세요.

tfLimitQuality

0x00040000

262144

모든 전환의 입력:출력 비율이 Amount:SendMax 비율과 같거나 더 좋은 경로만 사용합니다. 자세한 내용은 품질 제한을 참조하십시오.

부분 결제

부분 결제를 사용하면 수령 금액을 줄여서 결제가 성공할 수 있습니다. 부분 결제는 추가 비용을 발생시키지 않고 결제를 반환하는 데 유용합니다. 그러나 부분 결제는 성공적인 트랜잭션의 금액 필드에 항상 정확한 금액이 표시된다고 순진하게 가정하는 통합을 악용하는 데 사용될 수도 있습니다.

부분 결제는 tfPartialPayment 플래그가 활성화된 모든 결제 트랜잭션입니다. 부분 결제는 SendMax 값보다 많은 금액을 전송하지 않고 DeliverMin 필드보다 크거나 같은 양수 금액(DeliverMin이 지정되지 않은 경우 전혀 양수 금액)을 전송하는 경우 성공할 수 있습니다.

결제 메타데이터의 delivered_amount 필드는 대상 계정에서 실제로 수령한 화폐 금액을 나타냅니다.

자세한 내용은 부분 결제에 대한 전체 문서를 참조하세요.

품질 제한

XRP Ledger은 환전소의 "품질"을 들어오는 숫자와 나가는 숫자의 비율로 정의합니다. 예를 들어, 2달러를 사용해 1파운드(GBP)를 받는다면 해당 환전소의 "품질"은 0.5입니다.

tfLimitQuality 플래그를 사용하면 수락할 수 있는 최소 전환 품질을 설정할 수 있습니다. 이 제한 품질은 목적지 금액을 SendMax 금액으로 나눈 값으로 정의됩니다(화폐와 관계없이 숫자 금액만 해당). 설정하면 결제 처리 엔진은 품질(전환율)이 한도 품질보다 더 나쁜(수치상 더 낮은) 경로를 사용하지 않습니다.

tfLimitQuality 플래그는 그 자체로 트랜잭션이 성공할 수 있는 상황의 수를 줄입니다. 구체적으로, 결제의 전체 평균 전환 품질이 한도 품질과 같거나 더 좋더라도 결제의 일부가 불리한 전환을 사용하는 경우 결제를 거부합니다. 이러한 방식으로 결제가 거부되면 트랜잭션 결과는 tecPATH_DRY입니다.

다음 예를 살펴보겠습니다. 100중국 위안(금액 = 100 CNY)을 20미국 달러(SendMax = 20 USD) 이하로 보내려고 하는 경우 한도 품질은 5입니다. 한 트레이더가 15달러에 95엔(비율은 USD당 약 6.3 CNY)을 제안하지만 시장에서 가장 좋은 제안은 2달러에 5엔(비율은 USD당 2.5 CNY)이라고 가정해 보겠습니다. 두 제안을 모두 받아들여 100 CNY를 송금한다면 평균 품질은 약 5.9로 17 USD가 소요됩니다.

tfLimitQuality 플래그가 설정되어 있지 않은 경우 이 트랜잭션은 17달러의 비용이 지정된 SendMax 이내이므로 성공할 것입니다. 그러나 tfLimitQuality 플래그를 설정하면 두 번째 제안을 받는 경로의 품질이 2.5로 제한 품질인 5보다 낮기 때문에 트랜잭션이 대신 실패합니다.

tfLimitQuality 플래그는 부분 결제와 함께 사용할 때 가장 유용합니다. 트랜잭션에 tfPartialPayment 및 tfLimitQuality가 모두 설정되어 있으면 트랜잭션은 한도 품질보다 낮은 전환을 사용하지 않고 대상 금액의 최대한 많은 금액을 전달합니다.

위의 예에서 95엔/$15 제안과 5엔/$2 제안이 있는 경우, 내 트랜잭션에 tfPartialPayment와 tfLimitQuality가 모두 활성화되어 있는 경우에는 상황이 달라집니다. SendMax를 20달러로 유지하고 목적지 금액을 100위안으로 유지하면 한도 품질은 여전히 5입니다. 그러나 부분 결제를 하기 때문에 목적지 금액 전체를 송금할 수 없는 경우 트랜잭션이 실패하는 대신 가능한 한 많은 금액을 송금합니다. 즉, 내 트랜잭션은 품질이 약 6.3인 95/$15 제안을 사용하지만 해당 제안의 품질이 2.5로 품질 한도인 5보다 낮기 때문에 5/$2 제안은 거부됩니다. 결국 트랜잭션은 전체 100엔이 아닌 95엔만 전달되지만, 낮은 환율로 인한 비용 낭비를 방지할 수 있습니다.

PreviousOfferCreateNextPaymentChannelClaim

Last updated 1 year ago

내부 유형
화폐 금액
화폐 금액
화폐 금액
XRP에서 XRP로 직접 결제
토큰 생성 또는 상환
교차 통화 결제
부분 결제