mirror of
https://github.com/status-im/status-keycard.git
synced 2025-01-11 22:34:51 +00:00
explain compilation
This commit is contained in:
parent
11bfc4a4bf
commit
c7e35b8aeb
21
README.md
21
README.md
@ -16,16 +16,24 @@ installed on the system. The gradle.properties file must contain the following p
|
||||
* im.status.gradle.gpshell.kek_key = the KEK key for the ISD
|
||||
* im.status.gradle.gpshell.kvn = the Key Version Number for the ISD
|
||||
|
||||
Testing is done with JUnit and performed on a real card. Although the tests are comprehensive, debugging is not easy
|
||||
because raw APDUs are not shown in the test log and there is no way to set breakpoints in the applet. Using a simulator
|
||||
like [jCardSim](https://github.com/licel/jcardsim) would make debugging easier but only a subset of bugs can be reliably
|
||||
found with this system. Code changes would be needed for tests to support jCardSim. The tests are run with the test task
|
||||
in gradle.
|
||||
Testing is done with JUnit and performed either on a real card or on [jCardSim](https://github.com/status-im/jcardsim).
|
||||
Although the tests are comprehensive, debugging on the real card is not easy because raw APDUs are not shown in the test
|
||||
log and there is no way to set breakpoints in the applet.
|
||||
|
||||
In order to test with the simulator, you need to pass these additional parameters to the JVM
|
||||
|
||||
```-noverify -Dim.status.wallet.test.simulated=true```
|
||||
|
||||
## Compilation
|
||||
1. Download and install the JavaCard 3.0.4 SDK from [Oracle](http://www.oracle.com/technetwork/java/javasebusiness/downloads/java-archive-downloads-javame-419430.html#java_card_kit-classic-3_0_4-rr-bin-do)
|
||||
2. Clone the Github repo for our fork of [jCardSim](https://github.com/status-im/jcardsim)
|
||||
3. Create a gradle.properties (see below for an example)
|
||||
4. Run `./gradlew build`
|
||||
|
||||
## Example gradle.properties file
|
||||
|
||||
```
|
||||
com.fidesmo.gradle.javacard.home=/home/username/javacard-2_2_2
|
||||
com.fidesmo.gradle.javacard.home=/home/username/javacard-3_0_4
|
||||
im.status.gradle.gpshell=/usr/local/bin/gpshell
|
||||
im.status.gradle.gpshell.isd=A000000003000000
|
||||
im.status.gradle.gpshell.mac_key=404142434445464748494a4b4c4d4e4f
|
||||
@ -36,6 +44,7 @@ im.status.gradle.gpshell.kvn=2
|
||||
|
||||
## Implementation notes
|
||||
|
||||
* The applet requires JavaCard 3.0.4 or later.
|
||||
* The class byte of the APDU is not checked since there are no conflicting INS code.
|
||||
* Automated tests using JUnit 5 are included. The test require the application to be already installed. The first
|
||||
card terminal found by Java will be used, to please disconnect all card terminals except the one to be used for
|
||||
|
@ -32,7 +32,7 @@ repositories {
|
||||
}
|
||||
|
||||
dependencies {
|
||||
testCompile(files("../jcardsim/target/jcardsim-3.0.5-SNAPSHOT.jar"))
|
||||
testCompile(files("../jcardsim/jcardsim-3.0.5-SNAPSHOT.jar"))
|
||||
testCompile('org.web3j:core:2.3.1')
|
||||
testCompile("org.bouncycastle:bcprov-jdk15on:1.58")
|
||||
testCompile("org.junit.jupiter:junit-jupiter-api:5.0.0")
|
||||
|
@ -12,6 +12,7 @@ import org.web3j.crypto.*;
|
||||
import org.web3j.protocol.Web3j;
|
||||
import org.web3j.protocol.core.DefaultBlockParameterName;
|
||||
import org.web3j.protocol.core.methods.request.RawTransaction;
|
||||
import org.web3j.protocol.core.methods.response.EthGetTransactionReceipt;
|
||||
import org.web3j.protocol.core.methods.response.EthSendTransaction;
|
||||
import org.web3j.protocol.http.HttpService;
|
||||
import org.web3j.tx.Transfer;
|
||||
@ -438,6 +439,8 @@ public class WalletAppletTest {
|
||||
}
|
||||
|
||||
assertFalse(ethSendTransaction.hasError());
|
||||
|
||||
EthGetTransactionReceipt receipt = web3j.ethGetTransactionReceipt(ethSendTransaction.getTransactionHash()).send();
|
||||
}
|
||||
|
||||
private KeyPairGenerator keypairGenerator() throws Exception {
|
||||
@ -487,7 +490,6 @@ public class WalletAppletTest {
|
||||
Method recoverFromSignature = Sign.class.getDeclaredMethod("recoverFromSignature", int.class, ecdsaSignature, byte[].class);
|
||||
recoverFromSignature.setAccessible(true);
|
||||
|
||||
|
||||
BigInteger publicKey = keyPair.getPublicKey();
|
||||
|
||||
int recId = -1;
|
||||
@ -499,8 +501,7 @@ public class WalletAppletTest {
|
||||
}
|
||||
}
|
||||
if (recId == -1) {
|
||||
throw new RuntimeException(
|
||||
"Could not construct a recoverable key. This should never happen.");
|
||||
throw new RuntimeException("Could not construct a recoverable key. This should never happen.");
|
||||
}
|
||||
|
||||
int headerByte = recId + 27;
|
||||
|
Loading…
x
Reference in New Issue
Block a user