FAVORLET
FAVORLETFAVORLET scanner
English
English
  • INTRODUCTION
    • FAVORLET
    • FAVORLET scanner
    • Style Guidelines
    • Use Case
      • 2023.03 Ultra Abu Dhabi | Ticket Admission Verification & Commemorative NFT Airdrop
      • 2023.12 KMCA <The Great Gatsby> | Admission Verification & Bling Parts Airdrop
  • FAVORLET GUIDELINES
    • Usage guidelines
      • Offline Verificaton
      • View NFT Collections
      • Send NFT
    • Biz guidelines
      • Holder verification with FAVORLET scanner
  • FOR DEVELOPERS
    • App2App Dev. Guidelines
      • Connect Wallet
      • Message Signature
      • Send Platform Coin
      • Execute Contract
    • Scanner API Guidelines
  • Service center
    • FAQ and Suggestions
  • Announcements
    • Release Note
    • Press Release (KR)
    • Partnership
    • Notice
      • [Dec 1st 2023] FAVORLET v3.0 Update
      • [June 14th 2023] Update Notice
      • [Mar 17th 2023] Update Notice
      • [Mar 10 2023] Ultra Abu Dhabi 2023
      • [Feb 24 2023] Update Notice
      • [Feb 07 2023] Fellaz NFT Ticket for Ultra Abu Dhabi 2023
  • FAVORLET POLICY
    • Terms of Service (Jul 21, 2023)
    • Privacy Policy (Jul 21, 2023)
    • Previous Terms
      • Privacy Policy (Sep 19, 2022)
      • Privacy Policy(May 18th, 2022)
  • FAVORLET SCANNER POLICY
    • Privacy Policy(2022-09-19)
  • FAVORLET
  • Xclusive
  • Fingerlabs
Powered by GitBook
On this page
  • 1. Request.sendCoin
  • 2. createDeepLink
  • 3. receipt
  1. FOR DEVELOPERS
  2. App2App Dev. Guidelines

Send Platform Coin

1. Request.sendCoin

Parameters

Name
Type
Description

chainId

number

Chain ID of the particular network

appName

string

Name that will appear when sending platform coin in FAVORLE app

transactions

object array

Information required to transfer platform coins (see below for details)

transactions object contains

Name
Type
Description

from

string

Address to send platform coin

to

string

Address to receive platform coin

value

string

전송할 코인의 양 Amount of coin to send

Response

Name
Type
Description

requestId

string

ID to track the operation or transaction request

expiredAt

number

The amount of time (in seconds) that an operation or transaction request expires.

Example

import { Request } from "favorlet.js";

const response = await Request.sendCoin({
  chainId: 8217, // 해당 체인 id
  appName: "BlockChainApp", // FAVORLET 앱에 노출
  transactions: [
    {
      from: "0x{address in hex}", // 코인을 전송할 주소
      to: "0x{address in hex}", // 코인을 받을 주소
      value: "1000000000000000000", // 전송할 코인의 양
    },
  ],
});

console.log(response);
/*
{
  requestId: "56ba790c-aceb-465b-a6f2-33d103b25596",
  expiredAt: 1667891675
}
*/

2. createDeepLink

Parameters

Type
Description

string

requestId received when requesting

Response

Type
Description

string

DeepLink to the request page in FAVORLET app

Example

import { createDeepLink } from "favorlet.js";

const deepLink = createDeepLink(response.requestId); // Request를 통해 받은 requestId

/*
- PC: 생성된 deepLink를 qrcode 라이브러리를 이용하여 QR 생성 후 스마트폰으로 스캔
- Mobile: window.location.href 등을 사용하여 생성된 deepLink로 직접 이동
*/
console.log(deepLink);
// https://app.favorlet.link/?requestId=56ba790c-aceb-465b-a6f2-33d103b25596

3. receipt

import { receipt } from "favorlet.js";

const result = await receipt(response.requestId); // Request를 통해 받은 requestId

console.log(result);
/*
- status에 따라 이후 분기 처리

### requested
{
  requestId: "56ba790c-aceb-465b-a6f2-33d103b25596",
  expiredAt: 1667891675,
  action: "sendCoin",
  transactions: [
    { status: "requested" }
  ]
}

### executed
{
  requestId: "56ba790c-aceb-465b-a6f2-33d103b25596",
  expiredAt: 1667891675,
  action: "sendCoin",
  transactions: [
    { status: "executed" }
  ]
}

### canceled
{
  requestId: "56ba790c-aceb-465b-a6f2-33d103b25596",
  expiredAt: 1667891675,
  action: "sendCoin",
  transactions: [
    { 
      status: "canceled",
      txHash: null,
      errorMessage: null
    }
  ]
}

### failed
{
  requestId: "56ba790c-aceb-465b-a6f2-33d103b25596",
  expiredAt: 1667891675,
  action: "sendCoin",
  transactions: [
    { 
      status: "failed",
      txHash: "0x5a4e16cfe0c21c3cd20456340b8614f585d951d9b931b515b11575d08142a6e2",
      errorMessage: "execution reverted : invalid id"
    }
  ]
}

### succeed
{
  requestId: "56ba790c-aceb-465b-a6f2-33d103b25596",
  expiredAt: 1667891675,
  action: "sendCoin",
  transactions: [
    { 
      status: "succeed",
      txHash: "0x5a4e16cfe0c21c3cd20456340b8614f585d951d9b931b515b11575d08142a6e2",
      errorMessage: null
    }
  ]
}
*/
PreviousMessage SignatureNextExecute Contract

Last updated 2 years ago