Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat(jsonrpc): jsonrpc supports finalized #6146

Closed
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
30 changes: 25 additions & 5 deletions framework/src/main/java/org/tron/core/Wallet.java
Original file line number Diff line number Diff line change
Expand Up @@ -29,6 +29,10 @@
import static org.tron.core.config.Parameter.DatabaseConstants.PROPOSAL_COUNT_LIMIT_MAX;
import static org.tron.core.services.jsonrpc.JsonRpcApiUtil.parseEnergyFee;
import static org.tron.core.services.jsonrpc.TronJsonRpcImpl.EARLIEST_STR;
import static org.tron.core.services.jsonrpc.TronJsonRpcImpl.FINALIZED_STR;
import static org.tron.core.services.jsonrpc.TronJsonRpcImpl.LATEST_STR;
import static org.tron.core.services.jsonrpc.TronJsonRpcImpl.PENDING_STR;
import static org.tron.core.services.jsonrpc.TronJsonRpcImpl.TAG_PENDING_SUPPORT_ERROR;
import static org.tron.core.vm.utils.FreezeV2Util.getV2EnergyUsage;
import static org.tron.core.vm.utils.FreezeV2Util.getV2NetUsage;
import static org.tron.protos.contract.Common.ResourceCode;
Expand Down Expand Up @@ -681,6 +685,20 @@ public Block getBlockByNum(long blockNum) {
}
}

public Block getSolidBlock() {
try {
long blockNum = getSolidBlockNum();
return chainBaseManager.getBlockByNum(blockNum).getInstance();
} catch (StoreException e) {
logger.info(e.getMessage());
return null;
}
}

public long getSolidBlockNum() {
return chainBaseManager.getDynamicPropertiesStore().getLatestSolidifiedBlockNum();
}

public BlockCapsule getBlockCapsuleByNum(long blockNum) {
try {
return chainBaseManager.getBlockByNum(blockNum);
Expand All @@ -706,10 +724,12 @@ public long getTransactionCountByBlockNum(long blockNum) {
public Block getByJsonBlockId(String id) throws JsonRpcInvalidParamsException {
if (EARLIEST_STR.equalsIgnoreCase(id)) {
return getBlockByNum(0);
} else if ("latest".equalsIgnoreCase(id)) {
} else if (LATEST_STR.equalsIgnoreCase(id)) {
return getNowBlock();
} else if ("pending".equalsIgnoreCase(id)) {
throw new JsonRpcInvalidParamsException("TAG pending not supported");
} else if (FINALIZED_STR.equalsIgnoreCase(id)) {
return getSolidBlock();
} else if (PENDING_STR.equalsIgnoreCase(id)) {
throw new JsonRpcInvalidParamsException(TAG_PENDING_SUPPORT_ERROR);
} else {
long blockNumber;
try {
Expand All @@ -724,8 +744,8 @@ public Block getByJsonBlockId(String id) throws JsonRpcInvalidParamsException {

public List<Transaction> getTransactionsByJsonBlockId(String id)
throws JsonRpcInvalidParamsException {
if ("pending".equalsIgnoreCase(id)) {
throw new JsonRpcInvalidParamsException("TAG pending not supported");
if (PENDING_STR.equalsIgnoreCase(id)) {
throw new JsonRpcInvalidParamsException(TAG_PENDING_SUPPORT_ERROR);
} else {
Block block = getByJsonBlockId(id);
return block != null ? block.getTransactionsList() : null;
Expand Down
Original file line number Diff line number Diff line change
@@ -1,8 +1,10 @@
package org.tron.core.services.jsonrpc;

import static org.tron.core.services.jsonrpc.TronJsonRpcImpl.EARLIEST_STR;
import static org.tron.core.services.jsonrpc.TronJsonRpcImpl.FINALIZED_STR;
import static org.tron.core.services.jsonrpc.TronJsonRpcImpl.LATEST_STR;
import static org.tron.core.services.jsonrpc.TronJsonRpcImpl.PENDING_STR;
import static org.tron.core.services.jsonrpc.TronJsonRpcImpl.TAG_PENDING_SUPPORT_ERROR;

import com.google.common.base.Throwables;
import com.google.common.primitives.Longs;
Expand Down Expand Up @@ -513,14 +515,17 @@ public static long parseEnergyFee(long timestamp, String energyPriceHistory) {
return -1;
}

public static long getByJsonBlockId(String blockNumOrTag) throws JsonRpcInvalidParamsException {
public static long getByJsonBlockId(String blockNumOrTag, Wallet wallet)
throws JsonRpcInvalidParamsException {
if (PENDING_STR.equalsIgnoreCase(blockNumOrTag)) {
throw new JsonRpcInvalidParamsException("TAG pending not supported");
throw new JsonRpcInvalidParamsException(TAG_PENDING_SUPPORT_ERROR);
}
if (StringUtils.isEmpty(blockNumOrTag) || LATEST_STR.equalsIgnoreCase(blockNumOrTag)) {
return -1;
} else if (EARLIEST_STR.equalsIgnoreCase(blockNumOrTag)) {
return 0;
} else if (FINALIZED_STR.equalsIgnoreCase(blockNumOrTag)) {
return wallet.getSolidBlockNum();
} else {
return ByteArray.jsonHexToLong(blockNumOrTag);
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -136,10 +136,13 @@ public enum RequestSource {
public static final String EARLIEST_STR = "earliest";
public static final String PENDING_STR = "pending";
public static final String LATEST_STR = "latest";
public static final String FINALIZED_STR = "finalized";
public static final String TAG_PENDING_SUPPORT_ERROR = "TAG pending not supported";

private static final String JSON_ERROR = "invalid json request";
private static final String BLOCK_NUM_ERROR = "invalid block number";
private static final String TAG_NOT_SUPPORT_ERROR = "TAG [earliest | pending] not supported";
private static final String TAG_NOT_SUPPORT_ERROR =
"TAG [earliest | pending | finalized] not supported";
private static final String QUANTITY_NOT_SUPPORT_ERROR =
"QUANTITY not supported, just support TAG as latest";
private static final String NO_BLOCK_HEADER = "header not found";
Expand Down Expand Up @@ -351,7 +354,8 @@ public String getLatestBlockNum() {
public String getTrxBalance(String address, String blockNumOrTag)
throws JsonRpcInvalidParamsException {
if (EARLIEST_STR.equalsIgnoreCase(blockNumOrTag)
|| PENDING_STR.equalsIgnoreCase(blockNumOrTag)) {
|| PENDING_STR.equalsIgnoreCase(blockNumOrTag)
|| FINALIZED_STR.equalsIgnoreCase(blockNumOrTag)) {
throw new JsonRpcInvalidParamsException(TAG_NOT_SUPPORT_ERROR);
} else if (LATEST_STR.equalsIgnoreCase(blockNumOrTag)) {
byte[] addressData = addressCompatibleToByteArray(address);
Expand Down Expand Up @@ -488,7 +492,8 @@ private String call(byte[] ownerAddressByte, byte[] contractAddressByte, long va
public String getStorageAt(String address, String storageIdx, String blockNumOrTag)
throws JsonRpcInvalidParamsException {
if (EARLIEST_STR.equalsIgnoreCase(blockNumOrTag)
|| PENDING_STR.equalsIgnoreCase(blockNumOrTag)) {
|| PENDING_STR.equalsIgnoreCase(blockNumOrTag)
|| FINALIZED_STR.equalsIgnoreCase(blockNumOrTag)) {
throw new JsonRpcInvalidParamsException(TAG_NOT_SUPPORT_ERROR);
} else if (LATEST_STR.equalsIgnoreCase(blockNumOrTag)) {
byte[] addressByte = addressCompatibleToByteArray(address);
Expand Down Expand Up @@ -523,7 +528,8 @@ public String getStorageAt(String address, String storageIdx, String blockNumOrT
public String getABIOfSmartContract(String contractAddress, String blockNumOrTag)
throws JsonRpcInvalidParamsException {
if (EARLIEST_STR.equalsIgnoreCase(blockNumOrTag)
|| PENDING_STR.equalsIgnoreCase(blockNumOrTag)) {
|| PENDING_STR.equalsIgnoreCase(blockNumOrTag)
|| FINALIZED_STR.equalsIgnoreCase(blockNumOrTag)) {
throw new JsonRpcInvalidParamsException(TAG_NOT_SUPPORT_ERROR);
} else if (LATEST_STR.equalsIgnoreCase(blockNumOrTag)) {
byte[] addressData = addressCompatibleToByteArray(contractAddress);
Expand Down Expand Up @@ -823,7 +829,8 @@ public String getCall(CallArguments transactionCall, Object blockParamObj)
}

if (EARLIEST_STR.equalsIgnoreCase(blockNumOrTag)
|| PENDING_STR.equalsIgnoreCase(blockNumOrTag)) {
|| PENDING_STR.equalsIgnoreCase(blockNumOrTag)
|| FINALIZED_STR.equalsIgnoreCase(blockNumOrTag)) {
throw new JsonRpcInvalidParamsException(TAG_NOT_SUPPORT_ERROR);
} else if (LATEST_STR.equalsIgnoreCase(blockNumOrTag)) {
byte[] addressData = addressCompatibleToByteArray(transactionCall.getFrom());
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -51,15 +51,15 @@ public LogFilterWrapper(FilterRequest fr, long currentMaxBlockNum, Wallet wallet
// then if toBlock < maxBlockNum, set fromBlock = toBlock
// then if toBlock >= maxBlockNum, set fromBlock = maxBlockNum
if (StringUtils.isEmpty(fr.getFromBlock()) && StringUtils.isNotEmpty(fr.getToBlock())) {
toBlockSrc = JsonRpcApiUtil.getByJsonBlockId(fr.getToBlock());
toBlockSrc = JsonRpcApiUtil.getByJsonBlockId(fr.getToBlock(), wallet);
if (toBlockSrc == -1) {
toBlockSrc = Long.MAX_VALUE;
}
fromBlockSrc = Math.min(toBlockSrc, currentMaxBlockNum);

} else if (StringUtils.isNotEmpty(fr.getFromBlock())
&& StringUtils.isEmpty(fr.getToBlock())) {
fromBlockSrc = JsonRpcApiUtil.getByJsonBlockId(fr.getFromBlock());
fromBlockSrc = JsonRpcApiUtil.getByJsonBlockId(fr.getFromBlock(), wallet);
if (fromBlockSrc == -1) {
fromBlockSrc = currentMaxBlockNum;
}
Expand All @@ -70,8 +70,8 @@ public LogFilterWrapper(FilterRequest fr, long currentMaxBlockNum, Wallet wallet
toBlockSrc = Long.MAX_VALUE;

} else {
fromBlockSrc = JsonRpcApiUtil.getByJsonBlockId(fr.getFromBlock());
toBlockSrc = JsonRpcApiUtil.getByJsonBlockId(fr.getToBlock());
fromBlockSrc = JsonRpcApiUtil.getByJsonBlockId(fr.getFromBlock(), wallet);
toBlockSrc = JsonRpcApiUtil.getByJsonBlockId(fr.getToBlock(), wallet);
if (fromBlockSrc == -1 && toBlockSrc == -1) {
fromBlockSrc = currentMaxBlockNum;
toBlockSrc = Long.MAX_VALUE;
Expand Down
23 changes: 17 additions & 6 deletions framework/src/test/java/org/tron/core/WalletTest.java
Original file line number Diff line number Diff line change
Expand Up @@ -139,7 +139,7 @@ public class WalletTest extends BaseTest {
private static boolean init;

static {
Args.setParam(new String[]{"-d", dbPath()}, Constant.TEST_CONF);
Args.setParam(new String[] {"-d", dbPath()}, Constant.TEST_CONF);
OWNER_ADDRESS = Wallet.getAddressPreFixString() + "548794500882809695a8a687866e76d4271a1abc";
RECEIVER_ADDRESS = Wallet.getAddressPreFixString() + "abd4b9367799eaa3197fecb144eb71de1e049150";
}
Expand All @@ -152,7 +152,8 @@ public void before() {
}
initTransaction();
initBlock();
chainBaseManager.getDynamicPropertiesStore().saveLatestBlockHeaderNumber(5);
chainBaseManager.getDynamicPropertiesStore().saveLatestBlockHeaderNumber(BLOCK_NUM_FIVE);
chainBaseManager.getDynamicPropertiesStore().saveLatestSolidifiedBlockNum(BLOCK_NUM_TWO);
chainBaseManager.getDelegatedResourceStore().reset();
init = true;
}
Expand All @@ -166,6 +167,7 @@ private void initTransaction() {
TRANSACTION_TIMESTAMP_ONE, BLOCK_NUM_ONE);
addTransactionToStore(transaction1);

// solidified
transaction2 = getBuildTransaction(
getBuildTransferContract(ACCOUNT_ADDRESS_TWO, ACCOUNT_ADDRESS_THREE),
TRANSACTION_TIMESTAMP_TWO, BLOCK_NUM_TWO);
Expand Down Expand Up @@ -284,6 +286,7 @@ private void initBlock() {

private void addBlockToStore(Block block) {
BlockCapsule blockCapsule = new BlockCapsule(block);
chainBaseManager.getBlockIndexStore().put(blockCapsule.getBlockId());
chainBaseManager.getBlockStore().put(blockCapsule.getBlockId().getBytes(), blockCapsule);
}

Expand Down Expand Up @@ -1169,19 +1172,19 @@ public void testListNodes() {
* delegate_balance = 1000_000L; => 277
* delegate_balance = 1000_000_000L; => 279
* delegate_balance = 1000_000_000_000L => 280
*
* <p>
* We initialize account information as follows
* account balance = 1000_000_000_000L
* account frozen_balance = 1000_000_000L
*
* <p>
* then estimateConsumeBandWidthSize cost 279
*
* <p>
* so we have following result:
* TransactionUtil.estimateConsumeBandWidthSize(
* dynamicStore,ownerCapsule.getBalance()) ===> false
* TransactionUtil.estimateConsumeBandWidthSize(
* dynamicStore,ownerCapsule.getFrozenV2BalanceForBandwidth()) ===> true
*
* <p>
* This test case is used to verify the above conclusions
*/
@Test
Expand All @@ -1206,5 +1209,13 @@ public void testGetCanDelegatedMaxSizeBandWidth123() {
chainBaseManager.getDynamicPropertiesStore().saveMaxDelegateLockPeriod(DELEGATE_PERIOD / 3000);
}

@Test
public void testGetSolidBlock() {
long blkNum = wallet.getSolidBlockNum();
Assert.assertEquals(BLOCK_NUM_TWO, blkNum);

Block block = wallet.getSolidBlock();
assertEquals(block2, block);
}
}

104 changes: 1 addition & 103 deletions framework/src/test/java/org/tron/core/jsonrpc/JsonRpcTest.java
Original file line number Diff line number Diff line change
Expand Up @@ -190,6 +190,7 @@ public void testLogFilter() {
} catch (JsonRpcInvalidParamsException e) {
Assert.fail();
}

try {
new LogFilter(new FilterRequest(null, null, null, new String[] {"0x0"}, null));
} catch (JsonRpcInvalidParamsException e) {
Expand Down Expand Up @@ -240,109 +241,6 @@ public void testLogFilter() {
}
}

/**
* test fromBlock and toBlock parameters
*/
@Test
public void testLogFilterWrapper() {

// fromBlock and toBlock are both empty
try {
LogFilterWrapper logFilterWrapper =
new LogFilterWrapper(new FilterRequest(null, null, null, null, null), 100, null);
Assert.assertEquals(logFilterWrapper.getFromBlock(), 100);
Assert.assertEquals(logFilterWrapper.getToBlock(), Long.MAX_VALUE);
} catch (JsonRpcInvalidParamsException e) {
Assert.fail();
}

// fromBlock is not empty and smaller than currentMaxBlockNum, toBlock is empty
try {
LogFilterWrapper logFilterWrapper =
new LogFilterWrapper(new FilterRequest("0x14", null, null, null, null), 100, null);
Assert.assertEquals(logFilterWrapper.getFromBlock(), 20);
Assert.assertEquals(logFilterWrapper.getToBlock(), Long.MAX_VALUE);
} catch (JsonRpcInvalidParamsException e) {
Assert.fail();
}

// fromBlock is not empty and bigger than currentMaxBlockNum, toBlock is empty
try {
LogFilterWrapper logFilterWrapper =
new LogFilterWrapper(new FilterRequest("0x78", null, null, null, null), 100, null);
Assert.assertEquals(logFilterWrapper.getFromBlock(), 120);
Assert.assertEquals(logFilterWrapper.getToBlock(), Long.MAX_VALUE);
} catch (JsonRpcInvalidParamsException e) {
Assert.fail();
}

// fromBlock is empty, toBlock is not empty and smaller than currentMaxBlockNum
try {
LogFilterWrapper logFilterWrapper =
new LogFilterWrapper(new FilterRequest(null, "0x14", null, null, null), 100, null);
Assert.assertEquals(logFilterWrapper.getFromBlock(), 20);
Assert.assertEquals(logFilterWrapper.getToBlock(), 20);
} catch (JsonRpcInvalidParamsException e) {
Assert.fail();
}

// fromBlock is empty, toBlock is not empty and bigger than currentMaxBlockNum
try {
LogFilterWrapper logFilterWrapper =
new LogFilterWrapper(new FilterRequest(null, "0x78", null, null, null), 100, null);
Assert.assertEquals(logFilterWrapper.getFromBlock(), 100);
Assert.assertEquals(logFilterWrapper.getToBlock(), 120);
} catch (JsonRpcInvalidParamsException e) {
Assert.fail();
}

// fromBlock is not empty, toBlock is not empty
try {
LogFilterWrapper logFilterWrapper =
new LogFilterWrapper(new FilterRequest("0x14", "0x78", null, null, null), 100, null);
Assert.assertEquals(logFilterWrapper.getFromBlock(), 20);
Assert.assertEquals(logFilterWrapper.getToBlock(), 120);
} catch (JsonRpcInvalidParamsException e) {
Assert.fail();
}
try {
LogFilterWrapper logFilterWrapper =
new LogFilterWrapper(new FilterRequest("0x78", "0x14", null, null, null), 100, null);
} catch (JsonRpcInvalidParamsException e) {
Assert.assertEquals("please verify: fromBlock <= toBlock", e.getMessage());
}

//fromBlock or toBlock is not hex num
try {
LogFilterWrapper logFilterWrapper =
new LogFilterWrapper(new FilterRequest("earliest", null, null, null, null), 100, null);
Assert.assertEquals(logFilterWrapper.getFromBlock(), 0);
Assert.assertEquals(logFilterWrapper.getToBlock(), Long.MAX_VALUE);
} catch (JsonRpcInvalidParamsException e) {
Assert.fail();
}
try {
LogFilterWrapper logFilterWrapper =
new LogFilterWrapper(new FilterRequest("latest", null, null, null, null), 100, null);
Assert.assertEquals(logFilterWrapper.getFromBlock(), 100);
Assert.assertEquals(logFilterWrapper.getToBlock(), Long.MAX_VALUE);
} catch (JsonRpcInvalidParamsException e) {
Assert.fail();
}
try {
LogFilterWrapper logFilterWrapper =
new LogFilterWrapper(new FilterRequest("pending", null, null, null, null), 100, null);
} catch (JsonRpcInvalidParamsException e) {
Assert.assertEquals("TAG pending not supported", e.getMessage());
}
try {
LogFilterWrapper logFilterWrapper =
new LogFilterWrapper(new FilterRequest("test", null, null, null, null), 100, null);
} catch (JsonRpcInvalidParamsException e) {
Assert.assertEquals("Incorrect hex syntax", e.getMessage());
}
}

private int[] getBloomIndex(String s) {
Bloom bloom = Bloom.create(Hash.sha3(ByteArray.fromHexString(s)));
BitSet bs = BitSet.valueOf(bloom.getData());
Expand Down
Loading
Loading