moralis_sdk.js 7.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260
  1. /* import moralis */
  2. const Moralis = require("moralis/node");
  3. var utils = require('./utils.js');
  4. // var config = require('../config/config.js')(db_config,
  5. // moralis_config)
  6. var { moralis_config, reids_token_config } = require('../config/config.js')
  7. const redis = require("./redis_db") //导入 db.js
  8. const mysql = require("./mysql_db")
  9. /* Moralis init code */
  10. var serverUrl = moralis_config.SERVER_URL;
  11. var appId = moralis_config.APP_ID;
  12. var masterKey = moralis_config.MASTER_KEY;
  13. var moralisSecret = moralis_config.MORALIS_SECRET;
  14. // 内部异常
  15. const ERROR_CODE_001 = -1;
  16. const SUCCEED_CODE = 0;
  17. /**
  18. * 初始化 moralis
  19. * https://st94nif1cq.feishu.cn/docs/doccnNxG2UwHPCdZXbywgbdy13f#
  20. */
  21. async function initMasterSDK() {
  22. await Moralis.start({ serverUrl, appId, masterKey });
  23. }
  24. async function initMoralisSecretSDK() {
  25. await Moralis.start({ serverUrl, appId, moralisSecret });
  26. }
  27. function toJson(code_, obj_, errMsg_) {
  28. return utils.toJson(code_, obj_, errMsg_);
  29. }
  30. const withdraw = async (obj) => {
  31. obj.withdraw = 1;
  32. return await transfer(obj);
  33. }
  34. const transfer = async (obj) => {
  35. console.debug("fun transfer in ", obj);
  36. console.debug("fun transfer serverUrl ", serverUrl);
  37. console.debug("fun transfer appId ", serverUrl);
  38. console.debug("fun transfer moralisSecret ", moralisSecret);
  39. await initMoralisSecretSDK();
  40. // initSDK(moralisSecret);
  41. console.debug("fun transfer start ok ");
  42. const opts = {};
  43. opts.chainId = 'bsc_testnet';
  44. opts.privateKey = moralis_config.DEFAULT_PRIVATE_KEY;
  45. opts.type = "erc20"; //native erc20
  46. if (!obj.receiver || !obj.amount || parseFloat(obj.amount) <= 0) {
  47. console.error("fun transfer parameter error.");
  48. return toJson(ERROR_CODE_001, null, "please check receiver or amount parameter is ok ?");
  49. }
  50. if (obj.chain != null) {
  51. opts.chainId = utils.getChainId(obj.chain);
  52. console.log("chainId:", opts.chainId);
  53. }
  54. if (obj.type != null) {
  55. opts.type = obj.type;
  56. }
  57. if (obj.from_block != null) {
  58. opts.from_block = obj.from_block;
  59. }
  60. if (obj.to_block != null) {
  61. opts.to_block = obj.to_block;
  62. }
  63. opts.contractAddress = obj.contractAddress;
  64. opts.receiver = obj.receiver;
  65. //调用者传入
  66. // opts.amount = Moralis.Units.Token(obj.amount, 18);
  67. opts.amount = obj.amount;
  68. if (obj.privateKey != null) {
  69. opts.privateKey = obj.privateKey;
  70. }
  71. //解密私钥
  72. var privateKey = '';
  73. //提币
  74. if (obj.withdraw) {
  75. //读取归集地址私钥
  76. // opts.privateKey = readPriveteKeyFromMysql();
  77. opts.privateKey = '4Uz4Jm7Xd1gH+1nFbR0B7hk1ITmsT8O3iAgS/hC0L9TkrqAZoklsQhXl4fA1X+uqpckF4HtnXnMpwng94GvvzsRfXYirfDfboneuzfc0o7s=';
  78. }
  79. opts.privateKey = utils.decryptPrivityKey(opts.privateKey);
  80. if (!opts.privateKey) {
  81. return toJson(-1, null, "decryptPrivityKey error.");
  82. }
  83. console.log('decryptPrivityKey privateKey=', opts.privateKey)
  84. try {
  85. // sending 0.5 DAI tokens with 18 decimals on BSC testnet
  86. var options = Moralis.TransferOptions = {}
  87. if (opts.contractAddress) { //如果存在就是代币
  88. options = Moralis.TransferOptions = {
  89. type: opts.type,
  90. amount: opts.amount,
  91. receiver: opts.receiver, //接收钱包地址
  92. contractAddress: opts.contractAddress //用户合约地址
  93. };
  94. // console.log("options=",options);
  95. } else { //ETH or BNB
  96. options = Moralis.TransferOptions = {
  97. type: opts.type,
  98. amount: opts.amount,
  99. receiver: opts.receiver, //接收钱包地址
  100. };
  101. // console.log("options else=",options);
  102. }
  103. // Enable web3
  104. await Moralis.enableWeb3({
  105. //BSC mainnet = 0x38-56 testnet:0x61-97
  106. chainId: opts.chainId,
  107. privateKey: opts.privateKey,
  108. });
  109. var ret = await Moralis.transfer(options);
  110. return toJson(SUCCEED_CODE, ret, "");
  111. } catch (error) {
  112. console.log('transfer error:', error);
  113. if (error.reason != null) {
  114. return toJson(ERROR_CODE_001, null, error.toString());;
  115. } else {
  116. return toJson(ERROR_CODE_001, null, error);;
  117. }
  118. }
  119. };
  120. const getAllTokenWithdrawInfoLists = async (obj) => {
  121. try {
  122. var key = reids_token_config.TOKENWITHDRAW;
  123. var ret = await readRedis(key);
  124. return toJson(SUCCEED_CODE, ret, null);
  125. } catch (error) {
  126. console.error("getAllTokenWithdrawInfoLists=", error);
  127. return toJson(ERROR_CODE_001, null, error.toString());
  128. }
  129. }
  130. /**
  131. * 获取代币价格 -> usdPrice
  132. */
  133. const getAllTotkenPrice = async () => {
  134. try {
  135. console.log('当前环境:', process.env.NODE_ENV);
  136. console.log("getAllTotkenPrice in",reids_token_config); // Prints "value"
  137. var token_price_key = reids_token_config.TOKENPRICE;
  138. console.log("getAllTotkenPrice token_price_key=",token_price_key);
  139. return await redis.readRedis(token_price_key)
  140. } catch (error) {
  141. console.error("getTotkenPrice=", error);
  142. return toJson(ERROR_CODE_001, null, error.toString());
  143. }
  144. }
  145. //获取交易记录
  146. //hash 0xe09ba3a4c9f7a8902e01af68d0f1f91906f3f7db1195227e61c45c0e86b2630a
  147. async function getTokenTransfers(opt) {
  148. await initMasterSDK();
  149. console.debug("fun getTokenTransfers in ", opt);
  150. const options = {};
  151. options.type = 'all';
  152. options.chain = 'bsc_mainnet';
  153. if (opt.chain != null) {
  154. options.chain = utils.getChainName(opt.chain);
  155. console.log('getTokenTransfers=', options.chain);
  156. }
  157. if (opt.order != null) {
  158. options.order = opt.order;
  159. }
  160. if (opt.startTime != null) {
  161. options.from_date = opt.startTime;
  162. }
  163. if (opt.endTime != null) {
  164. options.to_date = opt.endTime;
  165. }
  166. if (opt.from_block != null) {
  167. options.from_block = opt.from_block;
  168. }
  169. if (opt.to_block != null) {
  170. options.to_block = opt.to_block;
  171. }
  172. if (opt.transaction_hash) {
  173. options.transaction_hash = opt.transaction_hash;
  174. options.type = 'transaction_hash';
  175. }
  176. console.debug('getTokenTransfers-->>>', options);
  177. if (options.type == 'all') {//查询主流币和 20 币所有的交易
  178. try {
  179. if (opt.address != null) {
  180. options.address = opt.address;
  181. } else {
  182. return toJson(ERROR_CODE_001, null, "please check address parameter is ok ?");
  183. }
  184. //主流币
  185. var t_1 = await Moralis.Web3API.account.getTransactions(options);
  186. //20币
  187. var t_2 = await Moralis.Web3API.account.getTokenTransfers(options);
  188. let arr = t_1.result;
  189. let arr1 = t_2.result;
  190. if (Array.isArray(arr1) && Array.isArray(arr)) {
  191. let arr2 = arr.concat(arr1);
  192. t_1.result = arr2;
  193. }
  194. return toJson(SUCCEED_CODE, t_1, null);
  195. } catch (error) {
  196. console.error("getTransactions error:", error)
  197. return toJson(ERROR_CODE_001, null, error);;
  198. }
  199. } else if (options.type == 'transaction_hash') {//根据哈希查询
  200. try {
  201. //native
  202. const transaction = await Moralis.Web3API.native.getTransaction(options);
  203. var arr = [];
  204. if (transaction)
  205. arr.push(transaction)
  206. var obj = { result: arr }
  207. return toJson(SUCCEED_CODE, obj, null);
  208. } catch (error) {
  209. console.error("native getTransaction error:", error)
  210. return toJson(ERROR_CODE_001, null, error);;
  211. }
  212. } else {
  213. return toJson(ERROR_CODE_001, null, "This type is not supported.");;
  214. }
  215. }
  216. module.exports = {
  217. transfer,
  218. getTokenTransfers,
  219. toJson,
  220. getAllTokenWithdrawInfoLists,
  221. getAllTotkenPrice,
  222. withdraw,
  223. }