moralis_sdk.js 8.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269
  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.chain);
  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. privateKey = utils.decryptPrivityKey(opts.privateKey);
  84. if (privateKey == null) {
  85. return toJson(-1, null, "decryptPrivityKey error.");
  86. }
  87. try {
  88. // sending 0.5 DAI tokens with 18 decimals on BSC testnet
  89. var options = Moralis.TransferOptions = {}
  90. if (opts.contractAddress) { //如果存在就是代币
  91. options = Moralis.TransferOptions = {
  92. type: opts.type,
  93. amount: opts.amount,
  94. receiver: opts.receiver, //接收钱包地址
  95. contractAddress: opts.contractAddress //用户合约地址
  96. };
  97. // console.log("options=",options);
  98. } else { //ETH or BNB
  99. options = Moralis.TransferOptions = {
  100. type: opts.type,
  101. amount: opts.amount,
  102. receiver: opts.receiver, //接收钱包地址
  103. };
  104. // console.log("options else=",options);
  105. }
  106. // Enable web3
  107. await Moralis.enableWeb3({
  108. //BSC mainnet = 0x38-56 testnet:0x61-97
  109. chainId: opts.chainId,
  110. privateKey: opts.privateKey,
  111. });
  112. var ret = await Moralis.transfer(options);
  113. return toJson(SUCCEED_CODE, ret, "");
  114. } catch (error) {
  115. console.log('transfer error:', error);
  116. if (error.reason != null) {
  117. return toJson(ERROR_CODE_001, null, error.toString());;
  118. } else {
  119. return toJson(ERROR_CODE_001, null, error);;
  120. }
  121. }
  122. };
  123. const getAllTokenWithdrawInfoLists = async (obj) => {
  124. try {
  125. var key = config.reids_token_config.TOKENWITHDRAW;
  126. var ret = await readRedis(key);
  127. return toJson(SUCCEED_CODE, ret, null);
  128. } catch (error) {
  129. console.error("getAllTokenWithdrawInfoLists=", error);
  130. return toJson(ERROR_CODE_001, null, error.toString());
  131. }
  132. }
  133. function readRedis(key) {
  134. return new Promise((resolve) => {
  135. redis.redis_get(key).then(result => {
  136. // console.log("redis_get=", JSON.parse(result)); // Prints "value"
  137. resolve(result);
  138. });
  139. })
  140. }
  141. /**
  142. * 获取代币价格 -> usdPrice
  143. */
  144. const getAllTotkenPrice = async () => {
  145. try {
  146. console.log("getAllTotkenPrice in"); // Prints "value"
  147. var token_price_key = config.reids_token_config.TOKENPRICE;
  148. return await readRedis(token_price_key)
  149. } catch (error) {
  150. console.error("getTotkenPrice=", error);
  151. return toJson(ERROR_CODE_001, null, error.toString());
  152. }
  153. }
  154. //获取交易记录
  155. //hash 0xe09ba3a4c9f7a8902e01af68d0f1f91906f3f7db1195227e61c45c0e86b2630a
  156. async function getTokenTransfers(opt) {
  157. await initMasterSDK();
  158. console.debug("fun getTokenTransfers in ", opt);
  159. const options = {};
  160. options.type = 'all';
  161. options.chain = 'bsc_mainnet';
  162. if (opt.chain != null) {
  163. options.chain = utils.getChainName(opt.chain);
  164. console.log('getTokenTransfers=', options.chain);
  165. }
  166. if (opt.order != null) {
  167. options.order = opt.order;
  168. }
  169. if (opt.startTime != null) {
  170. options.from_date = opt.startTime;
  171. }
  172. if (opt.endTime != null) {
  173. options.to_date = opt.endTime;
  174. }
  175. if (opt.from_block != null) {
  176. options.from_block = opt.from_block;
  177. }
  178. if (opt.to_block != null) {
  179. options.to_block = opt.to_block;
  180. }
  181. if (opt.transaction_hash) {
  182. options.transaction_hash = opt.transaction_hash;
  183. options.type = 'transaction_hash';
  184. }
  185. console.debug('getTokenTransfers-->>>', options);
  186. if (options.type == 'all') {//查询主流币和 20 币所有的交易
  187. try {
  188. if (opt.address != null) {
  189. options.address = opt.address;
  190. } else {
  191. return toJson(ERROR_CODE_001, null, "please check address parameter is ok ?");
  192. }
  193. //主流币
  194. var t_1 = await Moralis.Web3API.account.getTransactions(options);
  195. //20币
  196. var t_2 = await Moralis.Web3API.account.getTokenTransfers(options);
  197. let arr = t_1.result;
  198. let arr1 = t_2.result;
  199. if (Array.isArray(arr1) && Array.isArray(arr)) {
  200. let arr2 = arr.concat(arr1);
  201. t_1.result = arr2;
  202. }
  203. return toJson(SUCCEED_CODE, t_1, null);
  204. } catch (error) {
  205. console.error("getTransactions error:", error)
  206. return toJson(ERROR_CODE_001, null, error);;
  207. }
  208. } else if (options.type == 'transaction_hash') {//根据哈希查询
  209. try {
  210. //native
  211. const transaction = await Moralis.Web3API.native.getTransaction(options);
  212. var arr = [];
  213. if (transaction)
  214. arr.push(transaction)
  215. var obj = { result: arr }
  216. return toJson(SUCCEED_CODE, obj, null);
  217. } catch (error) {
  218. console.error("native getTransaction error:", error)
  219. return toJson(ERROR_CODE_001, null, error);;
  220. }
  221. } else {
  222. return toJson(ERROR_CODE_001, null, "This type is not supported.");;
  223. }
  224. }
  225. module.exports = {
  226. transfer,
  227. getTokenTransfers,
  228. toJson,
  229. getAllTokenWithdrawInfoLists,
  230. getAllTotkenPrice,
  231. withdraw,
  232. }