moralis_sdk.js 8.2 KB

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