diff --git a/.ci/ci_check.sh b/.ci/ci_check.sh index 08cb0939..a8d8fddc 100755 --- a/.ci/ci_check.sh +++ b/.ci/ci_check.sh @@ -114,13 +114,14 @@ bash gradlew test bash gradlew integrationTest --info } -LOG_INFO "------ check_java_version---------" +LOG_INFO "------ check java version --------" java -version #cp src/integration-test/resources/config-example.toml src/integration-test/resources/config.toml download_tassl -LOG_INFO "------ download_binary: v3.3.0---------" -download_binary "v3.3.0" -download_build_chain "v3.3.0" + +LOG_INFO "------ download_binary: v3.4.0---------" +download_binary "v3.4.0" +download_build_chain "v3.4.0" LOG_INFO "------ check_standard_node---------" check_standard_node false LOG_INFO "------ check_sm_node---------" @@ -128,6 +129,13 @@ check_sm_node true LOG_INFO "------ check_basic---------" check_basic +LOG_INFO "------ download_binary: v3.3.0---------" +download_binary "v3.3.0" +download_build_chain "v3.3.0" +LOG_INFO "------ check_standard_node---------" +check_standard_node +rm -rf ./bin + LOG_INFO "------ download_binary: v3.2.0---------" download_binary "v3.2.0" download_build_chain "v3.2.0" diff --git a/.github/workflows/workflow.yml b/.github/workflows/workflow.yml index 570f6df5..f226f62d 100644 --- a/.github/workflows/workflow.yml +++ b/.github/workflows/workflow.yml @@ -51,7 +51,12 @@ jobs: with: fetch-depth: 5 - name: install CentOS dependencies - run: yum install -y epel-release centos-release-scl which git openssl-devel openssl java java-devel wget + run: yum install -y epel-release centos-release-scl which git openssl-devel openssl wget + - name: Set up JDK 1.8 + uses: actions/setup-java@v3 + with: + distribution: 'zulu' + java-version: '8.0.345' - name: run integration testing run: /bin/bash -x .ci/ci_check.sh - name: upload coverage diff --git a/build.gradle b/build.gradle index 39c397e5..95ff6673 100644 --- a/build.gradle +++ b/build.gradle @@ -40,7 +40,7 @@ dependencies { //compile 'org.fisco-bcos:solcJ:0.5.2.1' compile 'org.fisco-bcos:solcJ:0.8.11.1' - compile('org.fisco-bcos.java-sdk:fisco-bcos-java-sdk:3.4.0') { + compile('org.fisco-bcos.java-sdk:fisco-bcos-java-sdk:3.5.0-SNAPSHOT') { exclude group: "org.slf4j" } @@ -55,7 +55,7 @@ dependencies { exclude group: "org.fisco-bcos.java-sdk" exclude group: "org.slf4j" } - compile ('com.fasterxml.jackson.core:jackson-databind:2.14.2'){ + compile ('com.fasterxml.jackson.core:jackson-databind:2.14.3'){ force true } testCompile('com.github.stefanbirkner:system-rules:1.19.0') diff --git a/release_note.txt b/release_note.txt index c219f723..c0c4025d 100644 --- a/release_note.txt +++ b/release_note.txt @@ -1 +1 @@ -v3.4.0 +v3.5.0 diff --git a/src/integration-test/java/console/ConsoleClientTest.java b/src/integration-test/java/console/ConsoleClientTest.java index 37f8dfe0..18298a3b 100644 --- a/src/integration-test/java/console/ConsoleClientTest.java +++ b/src/integration-test/java/console/ConsoleClientTest.java @@ -90,7 +90,7 @@ public void clientNotParamsTest() throws IOException { consoleClientFace.getGroupInfoList(emptyParams); assertTrue(log.getLog().startsWith("[")); log.clearLog(); - consoleClientFace.getNodeName(); + consoleClientFace.getNodeName(consoleInitializer); } @Test diff --git a/src/integration-test/java/console/TestBase.java b/src/integration-test/java/console/TestBase.java index e5ee762e..6e70a6cb 100644 --- a/src/integration-test/java/console/TestBase.java +++ b/src/integration-test/java/console/TestBase.java @@ -24,7 +24,7 @@ public static void setUpBeforeClass() throws Exception { consoleInitializer = new ConsoleInitializer(); consoleInitializer.init(new String[0]); isWasm = consoleInitializer.getClient().isWASM(); - isAuthCheck = consoleInitializer.getClient().isAuthCheck(); + isAuthCheck = consoleInitializer.getClient().isEnableCommittee(); authFace = consoleInitializer.getAuthFace(); consoleClientFace = consoleInitializer.getConsoleClientFace(); precompiledFace = consoleInitializer.getPrecompiledFace(); diff --git a/src/integration-test/resources/clog.ini b/src/integration-test/resources/clog.ini index d6647b9d..9041fec8 100644 --- a/src/integration-test/resources/clog.ini +++ b/src/integration-test/resources/clog.ini @@ -4,6 +4,6 @@ ; network statistics interval, unit is second, default is 60s stat_flush_interval=60 ; info debug trace - level=DEBUG + level=debug ; MB max_log_file_size=200 diff --git a/src/main/java/console/Console.java b/src/main/java/console/Console.java index 0d56961d..37e4b756 100644 --- a/src/main/java/console/Console.java +++ b/src/main/java/console/Console.java @@ -61,7 +61,7 @@ public static void main(String[] args) { WelcomeInfo.welcome(); String pwd = consoleInitializer.getPrecompiledFace().getPwd(); SupportedCommand.setIsAuthOpen( - consoleInitializer.getClient().isAuthCheck() + consoleInitializer.getClient().isEnableCommittee() && !consoleInitializer.getClient().isWASM()); SupportedCommand.setIsWasm(consoleInitializer.getClient().isWASM()); @@ -105,7 +105,7 @@ public static void main(String[] args) { SupportedCommand.getCommandInfo( params[0], consoleInitializer.getClient().isWASM(), - consoleInitializer.getClient().isAuthCheck()); + consoleInitializer.getClient().isEnableCommittee()); if (commandInfo != null) { if (CrudCommand.CRUD_COMMANDS.contains(params[0])) { String[] inputParamString = new String[1]; @@ -137,7 +137,7 @@ public static void main(String[] args) { // update the client when switch group JlineUtils.switchGroup(consoleInitializer.getClient()); SupportedCommand.setIsAuthOpen( - consoleInitializer.getClient().isAuthCheck() + consoleInitializer.getClient().isEnableCommittee() && !consoleInitializer.getClient().isWASM()); SupportedCommand.setIsWasm(consoleInitializer.getClient().isWASM()); } diff --git a/src/main/java/console/ConsoleInitializer.java b/src/main/java/console/ConsoleInitializer.java index a1ed779d..3a8920e3 100644 --- a/src/main/java/console/ConsoleInitializer.java +++ b/src/main/java/console/ConsoleInitializer.java @@ -6,6 +6,7 @@ import console.client.ConsoleClientImpl; import console.collaboration.CollaborationFace; import console.collaboration.CollaborationImpl; +import console.command.JlineUtils; import console.common.ConsoleUtils; import console.contract.ConsoleContractFace; import console.contract.ConsoleContractImpl; @@ -273,6 +274,8 @@ public void switchGroup(String[] params) { this.consoleContractFace = new ConsoleContractImpl(client); this.collaborationFace = new CollaborationImpl(client); this.authFace = new AuthImpl(client); + JlineUtils.switchGroup(client); + this.lineReader = JlineUtils.getLineReader(); System.out.println("Switched to group " + group + "."); System.out.println(); } catch (Exception e) { diff --git a/src/main/java/console/NonInteractiveConsole.java b/src/main/java/console/NonInteractiveConsole.java index 2dee6557..a4c0eaf5 100644 --- a/src/main/java/console/NonInteractiveConsole.java +++ b/src/main/java/console/NonInteractiveConsole.java @@ -40,7 +40,7 @@ public static void main(String[] args) { } SupportedCommand.isWasm = consoleInitializer.getClient().isWASM(); - SupportedCommand.isAuthOpen = consoleInitializer.getClient().isAuthCheck(); + SupportedCommand.isAuthOpen = consoleInitializer.getClient().isEnableCommittee(); try { String[] command = params[0].split(" "); CommandInfo commandInfo = null; @@ -50,13 +50,13 @@ public static void main(String[] args) { SupportedCommand.getCommandInfo( command[0], consoleInitializer.getClient().isWASM(), - consoleInitializer.getClient().isAuthCheck()); + consoleInitializer.getClient().isEnableCommittee()); } else { commandInfo = SupportedCommand.getCommandInfo( params[0], consoleInitializer.getClient().isWASM(), - consoleInitializer.getClient().isAuthCheck()); + consoleInitializer.getClient().isEnableCommittee()); } if (commandInfo != null) { if (CrudCommand.CRUD_COMMANDS.contains(command[0])) { diff --git a/src/main/java/console/auth/AuthImpl.java b/src/main/java/console/auth/AuthImpl.java index 55768f84..0ee66f14 100644 --- a/src/main/java/console/auth/AuthImpl.java +++ b/src/main/java/console/auth/AuthImpl.java @@ -1,7 +1,5 @@ package console.auth; -import static console.common.Common.COMPATIBILITY_VERSION; - import console.ConsoleInitializer; import console.common.ConsoleUtils; import java.math.BigInteger; @@ -16,6 +14,7 @@ import org.fisco.bcos.sdk.v3.contract.auth.po.CommitteeInfo; import org.fisco.bcos.sdk.v3.contract.auth.po.GovernorInfo; import org.fisco.bcos.sdk.v3.contract.auth.po.ProposalInfo; +import org.fisco.bcos.sdk.v3.contract.precompiled.sysconfig.SystemConfigService; import org.fisco.bcos.sdk.v3.crypto.keypair.CryptoKeyPair; import org.fisco.bcos.sdk.v3.model.PrecompiledRetCode; import org.fisco.bcos.sdk.v3.model.RetCode; @@ -36,7 +35,7 @@ public class AuthImpl implements AuthFace { public AuthImpl(Client client) { CryptoKeyPair cryptoKeyPair = client.getCryptoSuite().getCryptoKeyPair(); - boolean authAvailable = client.isAuthCheck() && !client.isWASM(); + boolean authAvailable = client.isEnableCommittee() && !client.isWASM(); if (authAvailable) { this.authManager = new AuthManager(client, cryptoKeyPair); } else { @@ -227,7 +226,8 @@ public void createSetSysConfigProposal(ConsoleInitializer consoleInitializer, St BigInteger proposalId = authManager.createSetSysConfigProposal(key, value); System.out.println("Set system config proposal created, ID is: " + proposalId); showProposalInfo(proposalId); - if (key.equals(COMPATIBILITY_VERSION) && proposalId.compareTo(BigInteger.ZERO) > 0) { + if (key.equals(SystemConfigService.COMPATIBILITY_VERSION) + && proposalId.compareTo(BigInteger.ZERO) > 0) { String[] param = new String[2]; param[1] = consoleInitializer.getGroupID(); consoleInitializer.switchGroup(param); diff --git a/src/main/java/console/client/ConsoleClientFace.java b/src/main/java/console/client/ConsoleClientFace.java index dc190c41..836a84fa 100644 --- a/src/main/java/console/client/ConsoleClientFace.java +++ b/src/main/java/console/client/ConsoleClientFace.java @@ -1,6 +1,7 @@ package console.client; import com.fasterxml.jackson.core.JsonProcessingException; +import console.ConsoleInitializer; import java.io.IOException; import org.fisco.bcos.sdk.v3.client.Client; @@ -15,6 +16,8 @@ public interface ConsoleClientFace { void getSealerList(String[] params) throws IOException; + void getCandidateSealerList(String[] params) throws IOException; + void getSyncStatus(String[] params) throws IOException; void getConsensusStatus(String[] params) throws IOException; @@ -61,9 +64,9 @@ public interface ConsoleClientFace { void getGroupNodeInfo(String[] params) throws JsonProcessingException; - void setNodeName(String[] params) throws IOException; + void setNodeName(ConsoleInitializer consoleInitializer, String[] params) throws IOException; - void clearNodeName(); + void clearNodeName(ConsoleInitializer consoleInitializer); - void getNodeName(); + void getNodeName(ConsoleInitializer consoleInitializer); } diff --git a/src/main/java/console/client/ConsoleClientImpl.java b/src/main/java/console/client/ConsoleClientImpl.java index 17c0120f..bca4e97b 100644 --- a/src/main/java/console/client/ConsoleClientImpl.java +++ b/src/main/java/console/client/ConsoleClientImpl.java @@ -1,6 +1,7 @@ package console.client; import com.fasterxml.jackson.core.JsonProcessingException; +import console.ConsoleInitializer; import console.client.model.TotalTransactionCountResult; import console.common.Common; import console.common.ConsoleUtils; @@ -33,7 +34,6 @@ public class ConsoleClientImpl implements ConsoleClientFace { private static final Logger logger = LoggerFactory.getLogger(ConsoleContractImpl.class); private Client client; - private String nodeName = ""; private static String EMPTY_HASH_HEX = "0x0000000000000000000000000000000000000000000000000000000000000000"; @@ -48,17 +48,17 @@ public void updateClient(Client client) { @Override public void getBlockNumber(String[] params) throws IOException { - System.out.println(client.getBlockNumber(nodeName).getBlockNumber()); + System.out.println(client.getBlockNumber().getBlockNumber()); } @Override public void getPbftView(String[] params) throws IOException { - System.out.println(client.getPbftView(nodeName).getPbftView()); + System.out.println(client.getPbftView().getPbftView()); } @Override public void getObserverList(String[] params) throws IOException { - String observers = client.getObserverList(nodeName).getObserverList().toString(); + String observers = client.getObserverList().getObserverList().toString(); if ("[]".equals(observers)) { System.out.println("[]"); } else { @@ -68,7 +68,18 @@ public void getObserverList(String[] params) throws IOException { @Override public void getSealerList(String[] params) throws IOException { - String sealers = client.getSealerList(nodeName).getSealerList().toString(); + String sealers = client.getSealerList().getSealerList().toString(); + if ("[]".equals(sealers)) { + System.out.println("[]"); + } else { + ConsoleUtils.printJson(sealers); + } + } + + @Override + public void getCandidateSealerList(String[] params) throws IOException { + String sealers = + client.getNodeListByType("consensus_candidate_sealer").getSealerList().toString(); if ("[]".equals(sealers)) { System.out.println("[]"); } else { @@ -78,7 +89,7 @@ public void getSealerList(String[] params) throws IOException { @Override public void getSyncStatus(String[] params) throws IOException { - ConsoleUtils.printJson(client.getSyncStatus(nodeName).getSyncStatus().toString()); + ConsoleUtils.printJson(client.getSyncStatus().getSyncStatus().toString()); } @Override @@ -106,7 +117,7 @@ public void getBlockByHash(String[] params) throws IOException { return; } } - BcosBlock.Block block = client.getBlockByHash(nodeName, blockHash, false, flag).getBlock(); + BcosBlock.Block block = client.getBlockByHash(blockHash, false, flag).getBlock(); if (block == null) { System.out.println("Block can not ne found, please check hash: " + blockHash); return; @@ -133,12 +144,12 @@ public void getBlockByNumber(String[] params) throws IOException { } } BcosBlock blockByNumber = - client.getBlockByNumber(nodeName, BigInteger.valueOf(blockNumber), false, flag); + client.getBlockByNumber(BigInteger.valueOf(blockNumber), false, flag); if (blockByNumber.getBlock() == null) { System.out.println("Block not found, please check number: " + blockNumber); } else { ConsoleUtils.printJson( - client.getBlockByNumber(nodeName, BigInteger.valueOf(blockNumber), false, flag) + client.getBlockByNumber(BigInteger.valueOf(blockNumber), false, flag) .getBlock() .toString()); } @@ -148,8 +159,7 @@ public void getBlockByNumber(String[] params) throws IOException { public void getBlockHeaderByHash(String[] params) throws IOException { String blockHash = params[1]; if (ConsoleUtils.isInvalidHash(blockHash)) return; - ConsoleUtils.printJson( - client.getBlockByHash(nodeName, blockHash, true, false).getBlock().toString()); + ConsoleUtils.printJson(client.getBlockByHash(blockHash, true, false).getBlock().toString()); } @Override @@ -178,7 +188,7 @@ public void getBlockHeaderByNumber(String[] params) throws IOException { return; } ConsoleUtils.printJson( - client.getBlockByNumber(nodeName, BigInteger.valueOf(blockNumber), true, false) + client.getBlockByNumber(BigInteger.valueOf(blockNumber), true, false) .getBlock() .toString()); } @@ -188,7 +198,7 @@ public void getTransactionByHash(String[] params) { String transactionHash = params[1]; if (ConsoleUtils.isInvalidHash(transactionHash)) return; JsonTransactionResponse transaction = - client.getTransaction(nodeName, transactionHash, false).getTransaction().get(); + client.getTransaction(transactionHash, false).getTransaction().get(); if (transaction == null) { System.out.println("This transaction hash doesn't exist."); return; @@ -202,9 +212,7 @@ public void getTransactionReceipt(String[] params) throws Exception { if (ConsoleUtils.isInvalidHash(transactionHash)) return; TransactionReceipt receipt = null; try { - receipt = - client.getTransactionReceipt(nodeName, transactionHash, false) - .getTransactionReceipt(); + receipt = client.getTransactionReceipt(transactionHash, false).getTransactionReceipt(); } catch (ClientException e) { System.out.println( "This transaction hash doesn't exist, errorMsg:" + e.getErrorMessage()); @@ -223,7 +231,7 @@ public void getTransactionByHashWithProof(String[] params) throws Exception { String transactionHash = params[1]; if (ConsoleUtils.isInvalidHash(transactionHash)) return; String transactionWithProof = - client.getTransaction(nodeName, transactionHash, true).getResult().toString(); + client.getTransaction(transactionHash, true).getResult().toString(); if (Objects.isNull(transactionWithProof) || transactionWithProof.isEmpty()) { System.out.println("This transaction hash doesn't exist."); @@ -239,9 +247,7 @@ public void getTransactionReceiptByHashWithProof(String[] params) throws Excepti String transactionReceiptWithProof; try { transactionReceiptWithProof = - client.getTransactionReceipt(nodeName, transactionHash, true) - .getResult() - .toString(); + client.getTransactionReceipt(transactionHash, true).getResult().toString(); } catch (ClientException e) { System.out.println( "This transaction hash doesn't exist, errorMsg:" + e.getErrorMessage()); @@ -257,7 +263,7 @@ public void getTransactionReceiptByHashWithProof(String[] params) throws Excepti @Override public void getPendingTxSize(String[] params) throws IOException { - String size = client.getPendingTxSize(nodeName).getResult(); + String size = client.getPendingTxSize().getResult(); System.out.println(Numeric.decodeQuantity(size)); } @@ -277,7 +283,7 @@ public void getCode(String[] params, boolean isWasm, String pwd) throws IOExcept return; } } - String code = client.getCode(nodeName, address).getCode(); + String code = client.getCode(address).getCode(); if ("0x".equals(code) || code.isEmpty()) { System.out.println("This address doesn't exist."); return; @@ -289,7 +295,7 @@ public void getCode(String[] params, boolean isWasm, String pwd) throws IOExcept public void getTotalTransactionCount(String[] params) throws IOException { TotalTransactionCount.TransactionCountInfo transactionCount = - client.getTotalTransactionCount(nodeName).getTotalTransactionCount(); + client.getTotalTransactionCount().getTotalTransactionCount(); TotalTransactionCountResult innerTotalTransactionCountResult = new TotalTransactionCountResult(); @@ -311,11 +317,11 @@ public void getTotalTransactionCount(String[] params) throws IOException { @Override public void getSystemConfigByKey(String[] params) throws Exception { String key = params[1]; - SystemConfig systemConfigByKey = client.getSystemConfigByKey(nodeName, key); + SystemConfig systemConfigByKey = client.getSystemConfigByKey(key); if (systemConfigByKey.getSystemConfig() == null) { System.out.println("System config not found, please check key: " + key); } else { - String value = client.getSystemConfigByKey(nodeName, key).getSystemConfig().getValue(); + String value = client.getSystemConfigByKey(key).getSystemConfig().getValue(); System.out.println(value); } } @@ -460,7 +466,7 @@ public void getGroupNodeInfo(String[] params) throws JsonProcessingException { } @Override - public void setNodeName(String[] params) { + public void setNodeName(ConsoleInitializer consoleInitializer, String[] params) { String newNodeName = params[1]; List nodeInfos = client.getGroupInfo().getResult().getNodeList(); @@ -478,23 +484,24 @@ public void setNodeName(String[] params) { + ", node not contains in node list, check command 'getGroupInfo'."); return; } - this.nodeName = newNodeName; - getNodeName(); + consoleInitializer.getClient().setNodeToSendRequest(newNodeName); + getNodeName(consoleInitializer); } @Override - public void clearNodeName() { + public void clearNodeName(ConsoleInitializer consoleInitializer) { System.out.println("Clear nodeName to empty."); - this.nodeName = ""; + consoleInitializer.getClient().setNodeToSendRequest(""); } @Override - public void getNodeName() { - if (this.nodeName.isEmpty()) { + public void getNodeName(ConsoleInitializer consoleInitializer) { + String nodeToSendRequest = consoleInitializer.getClient().getNodeToSendRequest(); + if (nodeToSendRequest.isEmpty()) { System.out.println( "Current default node name is empty, RPC will send request to node randomly."); return; } - System.out.println("Current default node name: " + this.nodeName); + System.out.println("Current default node name: " + nodeToSendRequest); } } diff --git a/src/main/java/console/command/JlineUtils.java b/src/main/java/console/command/JlineUtils.java index 59665a39..459d04f0 100644 --- a/src/main/java/console/command/JlineUtils.java +++ b/src/main/java/console/command/JlineUtils.java @@ -12,7 +12,6 @@ import console.command.completer.ContractMethodCompleter; import console.command.completer.CurrentPathCompleter; import console.command.completer.StringsCompleterIgnoreCase; -import console.common.Common; import console.contract.utils.ContractCompiler; import java.io.File; import java.io.IOException; @@ -20,9 +19,13 @@ import java.util.Arrays; import java.util.List; import org.fisco.bcos.sdk.v3.client.Client; +import org.fisco.bcos.sdk.v3.contract.precompiled.sysconfig.SystemConfigFeature; +import org.fisco.bcos.sdk.v3.contract.precompiled.sysconfig.SystemConfigService; +import org.fisco.bcos.sdk.v3.model.EnumNodeVersion; import org.jline.reader.Completer; import org.jline.reader.LineReader; import org.jline.reader.LineReaderBuilder; +import org.jline.reader.impl.LineReaderImpl; import org.jline.reader.impl.completer.AggregateCompleter; import org.jline.reader.impl.completer.ArgumentCompleter; import org.jline.reader.impl.completer.StringsCompleter; @@ -41,11 +44,13 @@ public class JlineUtils { private static AccountCompleter accountCompleter = null; private static CurrentPathCompleter currentPathCompleter = null; - public static LineReader getLineReader() throws IOException { - return createLineReader(new ArrayList()); + private static LineReader lineReader = null; + + public static LineReader getLineReader() { + return lineReader; } - public static void switchGroup(Client client) { + public static void switchGroup(Client client) throws IOException { if (contractAddressCompleter != null) { contractAddressCompleter.setClient(client); } @@ -58,6 +63,8 @@ public static void switchGroup(Client client) { if (currentPathCompleter != null) { currentPathCompleter.setClient(client); } + List completers = generateComplters(client); + ((LineReaderImpl) lineReader).setCompleter(new AggregateCompleter(completers)); } public static void switchPwd(String pwd) { @@ -66,10 +73,16 @@ public static void switchPwd(String pwd) { public static LineReader getLineReader(Client client) throws IOException { + List completers = generateComplters(client); + lineReader = createLineReader(completers); + return lineReader; + } + + private static List generateComplters(Client client) { List completers = new ArrayList<>(); List commands = - SupportedCommand.getAllCommand(client.isWASM(), client.isAuthCheck()); + SupportedCommand.getAllCommand(client.isWASM(), client.isEnableCommittee()); contractAddressCompleter = new ContractAddressCompleter(client); contractMethodCompleter = new ContractMethodCompleter(client); accountCompleter = new AccountCompleter(client); @@ -167,7 +180,7 @@ public static LineReader getLineReader(Client client) throws IOException { Arrays.asList( StatusQueryCommand.SET_SYSTEM_CONFIG_BY_KEY.getCommand(), StatusQueryCommand.GET_SYSTEM_CONFIG_BY_KEY.getCommand())); - if (client.isAuthCheck()) { + if (client.isEnableCommittee()) { commands.add(AuthOpCommand.SET_SYS_CONFIG_PROPOSAL.getCommand()); } @@ -175,29 +188,41 @@ public static LineReader getLineReader(Client client) throws IOException { completers.add( new ArgumentCompleter( new StringsCompleter(command), - new StringsCompleter(Common.TX_COUNT_LIMIT), + new StringsCompleter(SystemConfigService.TX_COUNT_LIMIT), new StringsCompleterIgnoreCase())); completers.add( new ArgumentCompleter( new StringsCompleter(command), - new StringsCompleter(Common.TX_GAS_LIMIT), + new StringsCompleter(SystemConfigService.TX_GAS_LIMIT), new StringsCompleterIgnoreCase())); completers.add( new ArgumentCompleter( new StringsCompleter(command), - new StringsCompleter(Common.CONSENSUS_LEADER_PERIOD), + new StringsCompleter(SystemConfigService.CONSENSUS_PERIOD), new StringsCompleterIgnoreCase())); completers.add( new ArgumentCompleter( new StringsCompleter(command), - new StringsCompleter(Common.COMPATIBILITY_VERSION), + new StringsCompleter(SystemConfigService.COMPATIBILITY_VERSION), new StringsCompleterIgnoreCase())); completers.add( new ArgumentCompleter( new StringsCompleter(command), - new StringsCompleter(Common.AUTH_CHECK_STATUS), + new StringsCompleter(SystemConfigService.AUTH_STATUS), new StringsCompleterIgnoreCase())); + for (SystemConfigFeature.Features feature : SystemConfigFeature.Features.values()) { + if (client.getChainCompatibilityVersion() + .compareTo( + EnumNodeVersion.convertToVersion(feature.enableVersion())) + >= 0) { + completers.add( + new ArgumentCompleter( + new StringsCompleter(command), + new StringsCompleter(feature.toString()), + new StringsCompleterIgnoreCase())); + } + } } completers.add( new ArgumentCompleter( @@ -219,7 +244,7 @@ public static LineReader getLineReader(Client client) throws IOException { currentPathCompleter, new StringsCompleterIgnoreCase())); } - return createLineReader(completers); + return completers; } public static LineReader createLineReader(List completers) throws IOException { diff --git a/src/main/java/console/command/category/BasicCommand.java b/src/main/java/console/command/category/BasicCommand.java index f2f9e7af..c74063a9 100644 --- a/src/main/java/console/command/category/BasicCommand.java +++ b/src/main/java/console/command/category/BasicCommand.java @@ -71,7 +71,9 @@ public Map getAllCommandInfo(boolean isWasm) { "Set default node name to send request.", HelpInfo::setNodeNameHelp, (consoleInitializer, params, pwd) -> - consoleInitializer.getConsoleClientFace().setNodeName(params), + consoleInitializer + .getConsoleClientFace() + .setNodeName(consoleInitializer, params), 1, 1); @@ -81,7 +83,9 @@ public Map getAllCommandInfo(boolean isWasm) { "Get default node name in this client.", HelpInfo::getNodeNameHelp, (consoleInitializer, params, pwd) -> - consoleInitializer.getConsoleClientFace().getNodeName(), + consoleInitializer + .getConsoleClientFace() + .getNodeName(consoleInitializer), 0, 0); @@ -91,7 +95,9 @@ public Map getAllCommandInfo(boolean isWasm) { "Clear default node name to empty.", HelpInfo::clearNodeNameHelp, (consoleInitializer, params, pwd) -> - consoleInitializer.getConsoleClientFace().clearNodeName(), + consoleInitializer + .getConsoleClientFace() + .clearNodeName(consoleInitializer), 0, 0); diff --git a/src/main/java/console/command/category/ConsensusOpCommand.java b/src/main/java/console/command/category/ConsensusOpCommand.java index 05717414..200a76a1 100644 --- a/src/main/java/console/command/category/ConsensusOpCommand.java +++ b/src/main/java/console/command/category/ConsensusOpCommand.java @@ -68,6 +68,15 @@ public Map getAllCommandInfo(boolean isWasm) { (consoleInitializer, params, pwd) -> consoleInitializer.getConsoleClientFace().getObserverList(params)); + public static final CommandInfo GET_CANDIDATE_LIST = + new CommandInfo( + "getCandidateList", + "Query nodeId list for candidate sealer nodes.", + HelpInfo::getCandidateListHelp, + (consoleInitializer, params, pwd) -> + consoleInitializer + .getConsoleClientFace() + .getCandidateSealerList(params)); public static final CommandInfo GET_PBFT_VIEW = new CommandInfo( "getPbftView", diff --git a/src/main/java/console/command/model/CommandInfo.java b/src/main/java/console/command/model/CommandInfo.java index f5626bc3..f7b95ff9 100644 --- a/src/main/java/console/command/model/CommandInfo.java +++ b/src/main/java/console/command/model/CommandInfo.java @@ -281,7 +281,7 @@ public void callCommand(ConsoleInitializer consoleInitializer, String[] params, HelpInfo.printHelp( command, consoleInitializer.getClient().isWASM(), - consoleInitializer.getClient().isAuthCheck()); + consoleInitializer.getClient().isEnableCommittee()); return; } @@ -300,7 +300,7 @@ public void callCommand(ConsoleInitializer consoleInitializer, String[] params, HelpInfo.printHelp( command, consoleInitializer.getClient().isWASM(), - consoleInitializer.getClient().isAuthCheck()); + consoleInitializer.getClient().isEnableCommittee()); return; } // check version diff --git a/src/main/java/console/command/model/HelpInfo.java b/src/main/java/console/command/model/HelpInfo.java index 35209d8d..abb33fcc 100644 --- a/src/main/java/console/command/model/HelpInfo.java +++ b/src/main/java/console/command/model/HelpInfo.java @@ -3,6 +3,9 @@ import console.command.SupportedCommand; import console.common.Common; import console.common.ConsoleUtils; +import org.fisco.bcos.sdk.v3.contract.precompiled.sysconfig.SystemConfigFeature; +import org.fisco.bcos.sdk.v3.contract.precompiled.sysconfig.SystemConfigService; +import org.fisco.bcos.sdk.v3.model.EnumNodeVersion; public class HelpInfo { public static void promptHelp(String command) { @@ -90,6 +93,12 @@ public static void getObserverListHelp() { System.out.println("Usage: \ngetObserverList"); } + public static void getCandidateListHelp() { + System.out.println("Query nodeId list for candidate sealer nodes."); + System.out.println("NOTE: only for the consensus node of the rPBFT algorithm."); + System.out.println("Usage: \ngetCandidateList"); + } + public static void getSealerListHelp() { System.out.println("Query nodeId list for sealer nodes."); System.out.println("Usage: \ngetSealerList"); @@ -361,7 +370,7 @@ public static void systemConfigHelper() { System.out.println("* value -- The value of system config to be set."); System.out.println( " -- the value of " - + Common.COMPATIBILITY_VERSION + + SystemConfigService.COMPATIBILITY_VERSION + " " + Common.COMPATIBILITY_VERSION_DESC); System.out.println( @@ -374,19 +383,34 @@ public static void systemConfigHelper() { + "(default 3000000000)."); System.out.println( " -- the value of " - + Common.CONSENSUS_LEADER_PERIOD + + SystemConfigService.CONSENSUS_PERIOD + " " + Common.SYS_CONFIG_RANGE + "(default 1)."); System.out.println( - " -- the value of " + Common.AUTH_CHECK_STATUS + " " + Common.AUTH_CHECK_DESC); + " -- the value of " + + SystemConfigService.AUTH_STATUS + + " " + + Common.AUTH_CHECK_DESC); + for (SystemConfigFeature.Features feature : SystemConfigFeature.Features.values()) { + System.out.println( + " -- the feature of " + + feature.toString() + + " only enable when " + + SystemConfigService.COMPATIBILITY_VERSION + + " >= " + + EnumNodeVersion.convertToVersion(feature.enableVersion()) + .toVersionString() + + ", value can only set 1 or greater equal than 1."); + } } public static void getSystemConfigByKeyHelp() { System.out.println("Query a system config value by key."); System.out.println("Usage: \ngetSystemConfigByKey key"); + System.out.println("* key -- The name of system config."); System.out.println( - "* key -- The name of system config(tx_count_limit/tx_gas_limit/consensus_leader_period supported currently)."); + " -- supported keys: " + String.join(",", Common.SUPPORTED_SYSTEM_KEYS)); } public static void operateGroupHelp(String command, String operator) { diff --git a/src/main/java/console/common/Common.java b/src/main/java/console/common/Common.java index 4e9ce49c..717d3cb6 100644 --- a/src/main/java/console/common/Common.java +++ b/src/main/java/console/common/Common.java @@ -4,6 +4,8 @@ import java.util.ArrayList; import java.util.Arrays; import java.util.List; +import org.fisco.bcos.sdk.v3.contract.precompiled.sysconfig.SystemConfigFeature; +import org.fisco.bcos.sdk.v3.contract.precompiled.sysconfig.SystemConfigService; public class Common { @@ -21,11 +23,17 @@ private Common() {} public static final List SUPPORTED_SYSTEM_KEYS = new ArrayList<>( Arrays.asList( - TX_COUNT_LIMIT, - TX_GAS_LIMIT, - CONSENSUS_LEADER_PERIOD, - COMPATIBILITY_VERSION, - AUTH_CHECK_STATUS)); + SystemConfigService.TX_COUNT_LIMIT, + SystemConfigService.TX_GAS_LIMIT, + SystemConfigService.CONSENSUS_PERIOD, + SystemConfigService.COMPATIBILITY_VERSION, + SystemConfigService.AUTH_STATUS)); + + static { + for (SystemConfigFeature.Features feature : SystemConfigFeature.Features.values()) { + SUPPORTED_SYSTEM_KEYS.add(feature.toString()); + } + } public static final int INVALID_RETURN_NUMBER = -100; public static final long INVALID_LONG_VALUE = Long.MAX_VALUE; diff --git a/src/main/java/console/common/ConsoleVersion.java b/src/main/java/console/common/ConsoleVersion.java index 25369c5b..d373e0d3 100644 --- a/src/main/java/console/common/ConsoleVersion.java +++ b/src/main/java/console/common/ConsoleVersion.java @@ -2,7 +2,7 @@ public class ConsoleVersion { - public static final String Version = "3.4.0"; + public static final String Version = "3.5.0"; public static void main(String[] args) { System.out.println("console version: " + Version); diff --git a/src/main/java/console/contract/ConsoleContractImpl.java b/src/main/java/console/contract/ConsoleContractImpl.java index 07525d73..6d05175b 100644 --- a/src/main/java/console/contract/ConsoleContractImpl.java +++ b/src/main/java/console/contract/ConsoleContractImpl.java @@ -21,6 +21,7 @@ import java.io.FileWriter; import java.io.IOException; import java.io.PrintWriter; +import java.math.BigInteger; import java.nio.ByteBuffer; import java.nio.charset.StandardCharsets; import java.time.LocalDateTime; @@ -40,9 +41,11 @@ import org.fisco.bcos.sdk.v3.client.protocol.response.Abi; import org.fisco.bcos.sdk.v3.codec.ContractCodecException; import org.fisco.bcos.sdk.v3.codec.EventEncoder; +import org.fisco.bcos.sdk.v3.codec.datatypes.generated.tuples.generated.Tuple2; import org.fisco.bcos.sdk.v3.codec.wrapper.ABIDefinition; import org.fisco.bcos.sdk.v3.codec.wrapper.ABIDefinitionFactory; import org.fisco.bcos.sdk.v3.codec.wrapper.ContractABIDefinition; +import org.fisco.bcos.sdk.v3.contract.precompiled.bfs.BFSPrecompiled; import org.fisco.bcos.sdk.v3.contract.precompiled.bfs.BFSService; import org.fisco.bcos.sdk.v3.crypto.keypair.CryptoKeyPair; import org.fisco.bcos.sdk.v3.model.CryptoType; @@ -568,9 +571,16 @@ public void call(String[] params, String pwd) throws Exception { if (!address.isEmpty() && !address.equals(Common.EMPTY_CONTRACT_ADDRESS)) { String abi = client.getABI(address).getABI(); if (abi.isEmpty()) { - System.out.println( - "Resource " + path + " doesnt have abi, maybe this is not a link."); - return; + Tuple2> list = + bfsService.list(fixedBfsParam, BigInteger.ZERO, BigInteger.TEN); + if (list.getValue2().isEmpty() + || list.getValue2().get(0).getExt().size() < 2 + || list.getValue2().get(0).getExt().get(1).isEmpty()) { + System.out.println( + "Resource " + path + " doesnt have abi, maybe this is not a link."); + return; + } + abi = list.getValue2().get(0).getExt().get(1); } AbiAndBin abiAndBin = new AbiAndBin(abi, "", ""); String functionName = params[2]; diff --git a/src/main/java/console/precompiled/PrecompiledImpl.java b/src/main/java/console/precompiled/PrecompiledImpl.java index 35d6c17b..5c3a3b45 100644 --- a/src/main/java/console/precompiled/PrecompiledImpl.java +++ b/src/main/java/console/precompiled/PrecompiledImpl.java @@ -1,7 +1,5 @@ package console.precompiled; -import static console.common.Common.COMPATIBILITY_VERSION; - import console.ConsoleInitializer; import console.common.Common; import console.common.ConsoleUtils; @@ -121,7 +119,7 @@ public void setSystemConfigByKey(ConsoleInitializer consoleInitializer, String[] String value = params[2]; RetCode retCode = this.systemConfigService.setValueByKey(key, value); ConsoleUtils.printJson(retCode.toString()); - if (key.equals(COMPATIBILITY_VERSION) + if (key.equals(SystemConfigService.COMPATIBILITY_VERSION) && retCode.code == PrecompiledRetCode.CODE_SUCCESS.code) { String[] param = new String[2]; param[1] = consoleInitializer.getGroupID(); diff --git a/tools/download_console.sh b/tools/download_console.sh index 9eb5356d..72c81ea5 100755 --- a/tools/download_console.sh +++ b/tools/download_console.sh @@ -3,7 +3,7 @@ package_name="console.tar.gz" solcj_name="" solcj_default_version="solcJ-0.8.11.1.jar" only_solc_flag="" -default_version="3.4.0" +default_version="3.5.0" download_version="${default_version}" solc_download_version="3.0.0" specify_console=0 diff --git a/tools/get_account.sh b/tools/get_account.sh index 3b4a0a23..1b191171 100755 --- a/tools/get_account.sh +++ b/tools/get_account.sh @@ -130,15 +130,17 @@ main() LOG_INFO "Private Key (pem) : ${output_path}/0x${accountAddress}.pem" # echo "0x${privKey}" > ${output_path}/${accountAddress}.private.hex openssl ec -in ${output_path}/0x${accountAddress}.pem -pubout -out ${output_path}/0x${accountAddress}.pem.pub 2>/dev/null - LOG_INFO "Public Key (pem) : ${output_path}/0x${accountAddress}.pem.pub" + openssl ec -in ${output_path}/0x${accountAddress}.pem -pubout -out ${output_path}/0x${accountAddress}.public.pem 2>/dev/null + LOG_INFO "Public Key (pem) : ${output_path}/0x${accountAddress}.public.pem" else LOG_INFO "Note: the entered password cannot contain Chinese characters!" openssl pkcs12 -export -name key -nocerts -inkey "${output_path}/ecprivkey.pem" -out "${output_path}/0x${accountAddress}.p12" || $(rm ${output_path}/0x${accountAddress}.p12 && rm ${output_path}/ecprivkey.pem && exit 1) openssl ec -in ${output_path}/ecprivkey.pem -pubout -out ${output_path}/0x${accountAddress}.pem.pub 2>/dev/null + openssl ec -in ${output_path}/ecprivkey.pem -pubout -out ${output_path}/0x${accountAddress}.public.pem 2>/dev/null rm ${output_path}/ecprivkey.pem LOG_INFO "Account Address : 0x${accountAddress}" LOG_INFO "Private Key (p12) : ${output_path}/0x${accountAddress}.p12" - LOG_INFO "Public Key (pem) : ${output_path}/0x${accountAddress}.pem.pub" + LOG_INFO "Public Key (pem) : ${output_path}/0x${accountAddress}.public.pem" fi # LOG_INFO "Private Key (hex) : 0x${privKey}" # echo "0x${pubKey}" > ${output_path}/${accountAddress}.public.hex