示例#1
0
        public JArray getClaimGasUtxoList(string mongodbConnStr, string mongodbDatabase, string address, bool isGetUsed = true, int pageNum = 1, int pageSize = 10)
        {
            string findFliter = string.Empty;

            if (isGetUsed)
            {
                //已使用,未领取(可领取GAS)
                findFliter = "{addr:'" + address + "','asset':'0xc56f33fc6ecfcd0c225c4ab356fee59390af8560be0e930faebe74a6daff7c9b','used':{$ne:''},'claimed':''}";
            }
            else
            {
                //未使用,未领取(不可领取GAS)
                findFliter = "{addr:'" + address + "','asset':'0xc56f33fc6ecfcd0c225c4ab356fee59390af8560be0e930faebe74a6daff7c9b','used':'','claimed':''}";
            }

            //统计有多少NEO UTXO
            long utxoCount = mh.GetDataCount(mongodbConnStr, mongodbDatabase, "utxo", findFliter);

            if (utxoCount == 0)
            {
                return new JArray {
                           new JObject()
                           {
                               { "count", 0 }, { "list", new JArray {
                                                 } }
                           }
                }
            }
            ;
            //
            string sortStr = new JObject()
            {
                { "createHeight", 1 }
            }.ToString();
            var gasIssueJA = mh.GetDataPages(mongodbConnStr, mongodbDatabase, "utxo", sortStr, pageSize, pageNum, findFliter);

            int curHeight = (int)mh.Getdatablockheight(mongodbConnStr, mongodbDatabase).First()["blockDataHeight"];
            var res       = gasIssueJA.Select(utxo => {
                int start               = (int)utxo["createHeight"];
                int end                 = (isGetUsed ? (int)utxo["useHeight"] - 1 : curHeight);
                int value               = (int)utxo["value"];
                decimal issueSysfee     = mh.GetTotalSysFeeByBlock(mongodbConnStr, mongodbDatabase, end) - mh.GetTotalSysFeeByBlock(mongodbConnStr, mongodbDatabase, start - 1);//转入的这个块,属于当前地址,由于差额计算方法,需要开始-1
                decimal issueGasInBlock = countGas(start, end);
                decimal issueGas        = (issueSysfee + issueGasInBlock) / 100000000 * value;
                //
                var jo = (JObject)utxo;
                jo.Add("gas", issueGas.ToString());
                return(jo);
            }).ToArray();

            return(new JArray {
                new JObject()
                {
                    { "count", utxoCount },
                    { "list", new JArray {
                          res
                      } }
                }
            });
        }
示例#2
0
        public JObject getClaimGas(string mongodbConnStr, string mongodbDatabase, string address, bool isGetUsed = true)
        {
            decimal issueGas = 0;

            string findFliter = string.Empty;

            if (isGetUsed)
            {
                //已使用,未领取(可领取GAS)
                findFliter = "{addr:'" + address + "','asset':'0xc56f33fc6ecfcd0c225c4ab356fee59390af8560be0e930faebe74a6daff7c9b','used':{$ne:''},'claimed':''}";
            }
            else
            {
                //未使用,未领取(不可领取GAS)
                findFliter = "{addr:'" + address + "','asset':'0xc56f33fc6ecfcd0c225c4ab356fee59390af8560be0e930faebe74a6daff7c9b','used':'','claimed':''}";
            }
            JArray gasIssueJA = mh.GetData(mongodbConnStr, mongodbDatabase, "utxo", findFliter);


            foreach (JObject utxo in gasIssueJA)
            {
                int start = (int)utxo["createHeight"];
                int end   = -1;
                if (isGetUsed)
                {
                    end = (int)utxo["useHeight"] - 1; //转出的这块的gas属于转入地址
                }
                else
                {
                    //未花费以目前高度计算
                    end = (int)mh.Getdatablockheight(mongodbConnStr, mongodbDatabase).First()["blockDataHeight"];
                }
                int value = (int)utxo["value"];

                decimal issueSysfee     = mh.GetTotalSysFeeByBlock(mongodbConnStr, mongodbDatabase, end) - mh.GetTotalSysFeeByBlock(mongodbConnStr, mongodbDatabase, start);
                decimal issueGasInBlock = countGas(start, end);

                issueGas += (issueSysfee + issueGasInBlock) / 100000000 * value;
            }

            JObject J = new JObject();

            J.Add("gas", issueGas);
            J.Add("claims", gasIssueJA);

            return(J);
        }