You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

start.ts 9.5KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221
  1. import * as dotevnv from "dotenv"
  2. import {toUtf8String,parseUnits,ContractFactory, parseEther,JsonRpcProvider, Contract, JsonRpcSigner, Wallet,ContractTransactionResponse, MaxInt256
  3. ,Transaction,formatEther,
  4. ZeroHash,ethers,keccak256,id
  5. } from 'ethers'
  6. import chalk from "chalk";
  7. import {Calulator} from "../inc/calc";
  8. import { TokenIssuer } from "../inc/TokenIssuer";
  9. import {
  10. SecurityToken,
  11. SecurityToken__factory,
  12. } from '../typechain'
  13. // import { HardhatEthersSigner } from "@nomicfoundation/hardhat-ethers/signers";
  14. import { Partition } from '../inc/tokenData';
  15. import {checkReceipt,checkReceipt2, setProvider,getDeploymentAddresses,
  16. getElapsed, sleep,getBlockInfo} from '../inc/util'
  17. dotevnv.config();
  18. if (!process.env.RPCURL) {
  19. console.log(`No rpcur value specified...`)
  20. }
  21. console.log(`목적 서버 : ${process.env.RPCURL}`);
  22. async function getNonce(addr: string): Promise<number> {
  23. const nonce = await provider.getTransactionCount(addr);
  24. return nonce;
  25. }
  26. async function info(symbol: string) {
  27. const proxy = getDeploymentAddresses(symbol).address;
  28. console.log(`토큰 주소 : ${proxy}`);
  29. const token = new SecurityToken__factory(issuer).attach(proxy) as SecurityToken;
  30. await token.connect(admin);
  31. const ops = await token.operators();
  32. console.log(ops);
  33. // token.grantRole(keccak256('OPERATOR_ROLE'),'0xaaa')
  34. }
  35. async function testSecurity(symbol: string, operator: Wallet, tobeOperator: Wallet,holder: Wallet, user1: Wallet, user2: Wallet) {
  36. const proxy = getDeploymentAddresses(symbol).address;
  37. console.log(`토큰 주소 : ${proxy}`);
  38. const token = new SecurityToken__factory(operator).attach(proxy) as SecurityToken;
  39. await token.connect(operator);
  40. const decimals = await token.decimals();
  41. const digit = 10 ** Number(decimals);
  42. console.log(`토큰 자릿수 : ${decimals}`);
  43. const partitions = await token.getDefaultPartitions();
  44. //console.log(partitions);
  45. console.log(chalk.yellow('###################### 변경전 오퍼레이터 ###################################'))
  46. const ops = await token.operators();
  47. console.log(ops);
  48. console.log(chalk.yellow(`provided operator = ${operator.address}`));
  49. console.log(chalk.yellow('###################### KYC 전 사용자 잔고 ###################################'))
  50. let b = await token.balanceOf(holder);
  51. let holderBalance = (1/digit) * Number(b);
  52. console.log(`토큰보유자 잔고 = ${Number(holderBalance).toFixed(Number(decimals))}`);
  53. b = await token.balanceOf(user1);
  54. let bUser1 = Number((1/digit) * Number(b));
  55. b = await token.balanceOf(user2);
  56. let bUser2 = Number((1/digit) * Number(b));
  57. console.log(chalk.blue(
  58. `사용자1 잔고 : ${Number(bUser1).toFixed(Number(decimals))}\r\n사용자2 잔고 : ${Number(bUser2).toFixed(Number(decimals))}`
  59. ))
  60. console.log(chalk.bgCyan('###################### 사용자 권한테스트 시작 ###################################'))
  61. console.log(chalk.yellow('###################### 사용자 등록전 전송시도###################################'))
  62. if(await token.isTokenHolderKYC(user1)) {
  63. console.log(`user1 already kyced .. unKYC user1`);
  64. const r = await token.unKYCtokenHolders([user1]);
  65. await r.wait();
  66. }
  67. if(await token.isTokenHolderKYC(user2)) {
  68. console.log(`user2 already kyced .. .. unKYC user2`);
  69. const r = await token.unKYCtokenHolders([user2]);
  70. await r.wait();
  71. }
  72. try {
  73. let r = await token.operatorTransferByPartition(partitions[0],holder,user1,1 * digit,ZeroHash,ZeroHash,{gasLimit: 20000000});
  74. console.log(`txhash1 : ${r.hash}`)
  75. const receipt1 = await r.wait();
  76. console.log(receipt1.hash);
  77. r = await token.operatorTransferByPartition(partitions[0],holder,user2,1 * digit,ZeroHash,ZeroHash,{gasLimit: 20000000});
  78. const receipt2 = await r.wait();
  79. console.log(`txhash2 : ${r.hash}`)
  80. console.log('KYC전 토큰전송완료....');
  81. } catch(ex) {
  82. console.log(chalk.red('예정된 KYC전 토큰전송에러'));
  83. //console.log(ex);
  84. }
  85. console.log(chalk.yellow('###################### 사용자 등록(KYC) ###################################'))
  86. let ret = await token.KYCtokenHolders([user1,user2],{gasLimit: 20000000});
  87. console.log('wait for user KYCed...');
  88. await ret.wait();
  89. console.log(chalk.yellow('###################### 사용자 등록후 전송시도 ###################################'))
  90. ret = await token.operatorTransferByPartition(partitions[0],holder,user1,1 * digit ,ZeroHash,ZeroHash,{gasLimit: 20000000});
  91. console.log(`txhash1 : ${ret.hash}`)
  92. let receipt = await ret.wait();
  93. console.log(receipt.hash);
  94. ret = await token.operatorTransferByPartition(partitions[0],holder,user2,1 * digit ,ZeroHash,ZeroHash,{gasLimit: 20000000});
  95. console.log(`txhash2 : ${ret.hash}`)
  96. receipt = await ret.wait();
  97. console.log(receipt.hash);
  98. console.log(chalk.yellow('###################### 등록 후 사용자 잔고 ###################################'))
  99. b = await token.balanceOf(user1);
  100. bUser1 = Number((1/digit) * Number(b));
  101. b = await token.balanceOf(user2);
  102. bUser2 = Number((1/digit) * Number(b));
  103. console.log(chalk.blue(
  104. `사용자1 잔고 : ${Number(bUser1).toFixed(Number(decimals))}\r\n사용자2 잔고 : ${Number(bUser2).toFixed(Number(decimals))}`
  105. ))
  106. console.log(chalk.bgCyan('###################### 사용자 권한테스트 종료 ###################################'))
  107. console.log(chalk.bgGreenBright('###################### 오퍼레이터 권한테스트 시작 ###################################'))
  108. const newOperatorToken = await token.connect(tobeOperator);
  109. const adminToken = await token.connect(admin);
  110. console.log(chalk.green('###################### 변경전 오퍼레이터 전송시도###################################'))
  111. try {
  112. let r = await newOperatorToken.operatorTransferByPartition(partitions[0],holder,user1,1 * digit,ZeroHash,ZeroHash,{gasLimit: 20000000});
  113. console.log(`txhash1 : ${r.hash}`)
  114. const receipt1 = await r.wait();
  115. console.log(receipt1.hash);
  116. r = await newOperatorToken.operatorTransferByPartition(partitions[0],holder,user2,1 * digit,ZeroHash,ZeroHash,{gasLimit: 20000000});
  117. const receipt2 = await r.wait();
  118. console.log(`txhash2 : ${r.hash}`)
  119. console.log('오퍼레이터 등록 전 토큰전송완료....');
  120. } catch(ex) {
  121. console.log(chalk.red('예정된 오퍼레이터 등록전 전송 에러'));
  122. }
  123. console.log(chalk.yellow('###################### 오퍼레이터 권한 등록 ###################################'))
  124. ret = await adminToken.grantRole( id('OPERATOR_ROLE'),tobeOperator,{ gasLimit: 20000000});
  125. receipt = await ret.wait();
  126. console.log(receipt.status)
  127. console.log(chalk.green('###################### 오퍼레이터 권한등록 후 전송시도###################################'))
  128. try {
  129. let r = await newOperatorToken.operatorTransferByPartition(partitions[0],holder,user1,1 * digit,ZeroHash,ZeroHash,{gasLimit: 20000000});
  130. console.log(`txhash1 : ${r.hash}`)
  131. const receipt1 = await r.wait();
  132. console.log(receipt1.hash);
  133. r = await newOperatorToken.operatorTransferByPartition(partitions[0],holder,user2,1 * digit,ZeroHash,ZeroHash,{gasLimit: 20000000});
  134. const receipt2 = await r.wait();
  135. console.log(`txhash2 : ${r.hash}`)
  136. console.log('오퍼레이터 등록 후 토큰전송완료....');
  137. } catch(ex) {
  138. console.log(chalk.red('권한등록후 에러??????????????'));
  139. }
  140. b = await token.balanceOf(user1);
  141. bUser1 = Number((1/digit) * Number(b));
  142. b = await token.balanceOf(user2);
  143. bUser2 = Number((1/digit) * Number(b));
  144. console.log(chalk.blue(
  145. `사용자1 잔고 : ${Number(bUser1).toFixed(Number(decimals))}\r\n사용자2 잔고 : ${Number(bUser2).toFixed(Number(decimals))}`
  146. ))
  147. console.log(chalk.bgGreenBright('###################### 오퍼레이터 권한테스트 종료 ###################################'))
  148. console.log(chalk.yellow('###################### 테스트권한 클리어 ###################################'));
  149. await token.unKYCtokenHolders([user1, user2]);
  150. ret = await adminToken.revokeRole( id('OPERATOR_ROLE'),tobeOperator,{ gasLimit: 20000000});
  151. await ret.wait();
  152. }
  153. const calc = new Calulator();
  154. const rpcUrl = process.env.RPCURL;
  155. const provider = new JsonRpcProvider(rpcUrl);
  156. setProvider(provider);
  157. const admin = new Wallet('0xc87509a1c067bbde78beb793e6fa76530b6382a4c0241e5e4a9ec0a0f44dc0d3',provider);
  158. const issuer = new Wallet('0x8f2a55949038a9610f50fb23b5883af3b4ecb3c3bb792cbcefbd1542c692be63',provider);
  159. //const signer = issuer;
  160. const holder1 = new Wallet('0xae6ae8e5ccbfb04590405997ee2d52d2b330726137b875053c36d94e974d162f',provider);
  161. const holder2 = new Wallet('0xac0974bec39a17e36ba4a6b4d238ff944bacb478cbed5efcae784d7bf4f2ff80',provider);
  162. const user1 = new Wallet('5c7ff82446654833ed4cbd3dc7cca94b114b556def572a5f2f7f29224c757adb',provider);
  163. //0xB22f4c5fA701837dcBd037D60F5d2606050fBbd9
  164. const user2 = new Wallet('509157aeb1308d8ff8db8a3059d4392d92fb66960ef5083eda5a8dcc9118be31',provider);
  165. //0xA59D39340AEF8681248aaB3F71D104897FdF7c84
  166. const newOperator = new Wallet('a0e4679c61e04969499af0c4cdcdc66e9a9f2e3f6cbc17ede9e2137518f8e75d',provider);
  167. //0x1e5Ed00f65556374d7fb2039e2a11aDc64021762
  168. async function main() {
  169. await testSecurity('test003',issuer,newOperator,holder1, user1,user2);
  170. }
  171. main();