This repository has been archived by the owner on Feb 21, 2024. It is now read-only.
/
transferNftKMS.php
88 lines (67 loc) · 2.7 KB
/
transferNftKMS.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
<?php
/**
* Copyright (c) 2022-2023 tatum.io
*
* @link https://tatumio.github.io/tatum-php/Api/NFTERC721OrCompatibleApi/#transfernftkms
* @license MIT
* @author Mark Jivko
*
* SECURITY WARNING
* Execute this file in CLI mode only!
*/
"cli" !== php_sapi_name() && exit();
// Use any PSR-4 autoloader
require_once dirname(__DIR__, 3) . "/autoload.php";
// Set your API Keys 👇 here
$sdk = new \Tatum\Sdk();
// 🐛 Enable debugging on the MainNet
$sdk->mainnet()->config()->setDebug(true);
$arg_transfer_nft_kms = (new \Tatum\Model\TransferNftKMS())
// (optional) If token to be transferred is Royalty NFT token, this is a value to be paid as a cashback to the ...
->setValue('1')
// The blockchain to work with
->setChain('ETH')
// Blockchain address to send NFT token to
->setTo('0x687422eEA2cB73B5d3e242bA5456b782919AFc85')
// ID of the token.
->setTokenId('123')
// Address of NFT token
->setContractAddress('0x687422eEA2cB73B5d3e242bA5456b782919AFc85')
// (optional) If signatureId is mnemonic-based, this is the index to the specific address from that mnemonic.
->setIndex(null)
// (optional) True if the contract is provenance type
->setProvenance(true)
// (optional) data you want to store with transaction, optional and valid only if provenance contract
->setProvenanceData('test')
// (optional) current price of the token, valid only for provenance
->setTokenPrice('1')
// Identifier of the private key associated in signing application. Private key, or signature Id mus...
->setSignatureId('26d3883e-4e17-48b3-a0ee-09a3e484ac83')
// (optional) The nonce to be set to the transaction; if not present, the last known nonce will be used
->setNonce(1)
// (optional) \Tatum\Model\CustomFee
->setFee(null);
// Type of Ethereum testnet. Defaults to Sepolia. Valid only for ETH invocations for testnet API Key. For mainnet API Key, this value is ignored.
$arg_x_testnet_type = 'ethereum-sepolia';
try {
/**
* POST /v3/nft/transaction
*
* @var \Tatum\Model\TransactionSigned $response
*/
$response = $sdk->mainnet()
->api()
->nFTERC721OrCompatible()
->transferNftKMS($arg_transfer_nft_kms, $arg_x_testnet_type);
var_dump($response);
} catch (\Tatum\Sdk\ApiException $apiExc) {
echo sprintf(
"API Exception when calling api()->nFTERC721OrCompatible()->transferNftKMS(): %s\n",
var_export($apiExc->getResponseObject(), true)
);
} catch (\Exception $exc) {
echo sprintf(
"Exception when calling api()->nFTERC721OrCompatible()->transferNftKMS(): %s\n",
$exc->getMessage()
);
}