moralis_sdk.js 8.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266
  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 = config.moralis_config.test_server.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 = config.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. function readRedis(key) {
  131. return new Promise((resolve) => {
  132. redis.redis_get(key).then(result => {
  133. // console.log("redis_get=", JSON.parse(result)); // Prints "value"
  134. resolve(result);
  135. });
  136. })
  137. }
  138. /**
  139. * 获取代币价格 -> usdPrice
  140. */
  141. const getAllTotkenPrice = async () => {
  142. try {
  143. console.log('当前环境:', process.env.NODE_ENV);
  144. console.log("getAllTotkenPrice in"); // Prints "value"
  145. var token_price_key = reids_token_config.TOKENPRICE;
  146. return await readRedis(token_price_key)
  147. } catch (error) {
  148. console.error("getTotkenPrice=", error);
  149. return toJson(ERROR_CODE_001, null, error.toString());
  150. }
  151. }
  152. //获取交易记录
  153. //hash 0xe09ba3a4c9f7a8902e01af68d0f1f91906f3f7db1195227e61c45c0e86b2630a
  154. async function getTokenTransfers(opt) {
  155. await initMasterSDK();
  156. console.debug("fun getTokenTransfers in ", opt);
  157. const options = {};
  158. options.type = 'all';
  159. options.chain = 'bsc_mainnet';
  160. if (opt.chain != null) {
  161. options.chain = utils.getChainName(opt.chain);
  162. console.log('getTokenTransfers=', options.chain);
  163. }
  164. if (opt.order != null) {
  165. options.order = opt.order;
  166. }
  167. if (opt.startTime != null) {
  168. options.from_date = opt.startTime;
  169. }
  170. if (opt.endTime != null) {
  171. options.to_date = opt.endTime;
  172. }
  173. if (opt.from_block != null) {
  174. options.from_block = opt.from_block;
  175. }
  176. if (opt.to_block != null) {
  177. options.to_block = opt.to_block;
  178. }
  179. if (opt.transaction_hash) {
  180. options.transaction_hash = opt.transaction_hash;
  181. options.type = 'transaction_hash';
  182. }
  183. console.debug('getTokenTransfers-->>>', options);
  184. if (options.type == 'all') {//查询主流币和 20 币所有的交易
  185. try {
  186. if (opt.address != null) {
  187. options.address = opt.address;
  188. } else {
  189. return toJson(ERROR_CODE_001, null, "please check address parameter is ok ?");
  190. }
  191. //主流币
  192. var t_1 = await Moralis.Web3API.account.getTransactions(options);
  193. //20币
  194. var t_2 = await Moralis.Web3API.account.getTokenTransfers(options);
  195. let arr = t_1.result;
  196. let arr1 = t_2.result;
  197. if (Array.isArray(arr1) && Array.isArray(arr)) {
  198. let arr2 = arr.concat(arr1);
  199. t_1.result = arr2;
  200. }
  201. return toJson(SUCCEED_CODE, t_1, null);
  202. } catch (error) {
  203. console.error("getTransactions error:", error)
  204. return toJson(ERROR_CODE_001, null, error);;
  205. }
  206. } else if (options.type == 'transaction_hash') {//根据哈希查询
  207. try {
  208. //native
  209. const transaction = await Moralis.Web3API.native.getTransaction(options);
  210. var arr = [];
  211. if (transaction)
  212. arr.push(transaction)
  213. var obj = { result: arr }
  214. return toJson(SUCCEED_CODE, obj, null);
  215. } catch (error) {
  216. console.error("native getTransaction error:", error)
  217. return toJson(ERROR_CODE_001, null, error);;
  218. }
  219. } else {
  220. return toJson(ERROR_CODE_001, null, "This type is not supported.");;
  221. }
  222. }
  223. module.exports = {
  224. transfer,
  225. getTokenTransfers,
  226. toJson,
  227. getAllTokenWithdrawInfoLists,
  228. getAllTotkenPrice,
  229. withdraw,
  230. }