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

Initial support for elliptical curves #915

Merged
merged 37 commits into from
Nov 19, 2019
Merged

Initial support for elliptical curves #915

merged 37 commits into from
Nov 19, 2019

Conversation

melowe
Copy link
Contributor

@melowe melowe commented Nov 1, 2019

  1. Refactored encryption and config modules to allow support for alternative encryptors to NACL.
  2. Modified test fixture not to assume NACL.
  3. Refactored key pair loading to facilitate injection of encryptor.
  4. Moved new keypair password generation out of config module as this is essentially handling cli command/actions into the config cli module.

Cli changes
tessera -updatepassword requires --encryptor.type=[NACL|EC] option
tessera -keygen requires --encryptor.type=[NACL|EC] option or {encryptor : {type:NACL or EC } defining in config
normal usage default to NACL for backward compatibility.

enable tests for different encryptor implementations.
in our send scenerios. Add todo comments to failure scenerios documentating 
 the danger of false positives.
classloader. Temporary measure until config changes for alternative 
encryptors is added. 

Conflicts:
	encryption/encryption-api/src/main/java/com/quorum/tessera/encryption/EncryptorFactory.java
logic. Mock payloads in test in code module reducing cross impacts 
of any changes to encoding logic. 

Conflicts:
	enclave/enclave-api/src/main/java/com/quorum/tessera/enclave/EnclaveImpl.java
	enclave/enclave-api/src/main/java/com/quorum/tessera/enclave/EncodedPayload.java
	enclave/enclave-api/src/main/java/com/quorum/tessera/enclave/EncodedPayloadBuilder.java
	enclave/enclave-api/src/main/java/com/quorum/tessera/enclave/PayloadEncoderImpl.java
	enclave/enclave-api/src/test/java/com/quorum/tessera/enclave/EnclaveTest.java
	enclave/enclave-api/src/test/java/com/quorum/tessera/enclave/PayloadEncoderTest.java
	enclave/enclave-jaxrs/src/test/java/com/quorum/tessera/enclave/rest/Fixtures.java
	tessera-core/src/test/java/com/quorum/tessera/transaction/ResendManagerTest.java
	tessera-sync/src/test/java/com/quorum/tessera/sync/Fixtures.java
injection of properties as map for custom configuration when creating 
encryptors. 

Conflicts:
	encryption/encryption-api/src/main/java/com/quorum/tessera/encryption/EncryptorFactory.java
	encryption/encryption-api/src/test/java/com/quorum/tessera/encryption/MockEncryptorFactory.java
	encryption/encryption-jnacl/src/main/java/com/quorum/tessera/nacl/jnacl/JnaclFactory.java
	encryption/encryption-kalium/src/main/java/com/quorum/tessera/nacl/kalium/KaliumFactory.java
specifically elliptical curves. Changed test fixtures across project not to
assume nacl. 

Conflicts:
	config-migration/src/main/java/com/quorum/tessera/config/builder/ConfigBuilder.java
	config/src/main/java/com/quorum/tessera/config/keypairs/InlineKeypair.java
	config/src/main/java/com/quorum/tessera/config/keys/KeyEncryptorFactory.java
	enclave/enclave-api/src/main/java/com/quorum/tessera/enclave/EnclaveFactory.java
	encryption/encryption-api/src/test/java/com/quorum/tessera/encryption/EncryptorFactoryTest.java
	key-generation/src/main/java/com/quorum/tessera/key/generation/DefaultKeyGeneratorFactory.java
	key-generation/src/main/java/com/quorum/tessera/key/generation/FileKeyGenerator.java
	tests/acceptance-test/pom.xml
	tests/acceptance-test/src/test/java/com/quorum/tessera/test/P2pTestSuite.java
	tests/acceptance-test/src/test/java/com/quorum/tessera/test/cli/keygen/FileKeygenSteps.java
	tests/acceptance-test/src/test/java/com/quorum/tessera/test/grpc/GrpcSuite.java
	tests/acceptance-test/src/test/java/com/quorum/tessera/test/rest/RestSuite.java
	tests/acceptance-test/src/test/java/com/quorum/tessera/test/rest/RestSuiteSimple.java
	tests/acceptance-test/src/test/java/com/quorum/tessera/test/rest/SendWithRemoteEnclaveReconnectIT.java
	tests/acceptance-test/src/test/java/com/quorum/tessera/test/rest/StressRestSuite.java
	tests/acceptance-test/src/test/java/com/quorum/tessera/test/ws/RestSuiteP2pWebsocketH2.java
	tests/acceptance-test/src/test/java/config/ConfigBuilder.java
	tests/acceptance-test/src/test/java/suite/ExecutionContext.java
	tests/acceptance-test/src/test/java/suite/ProcessConfig.java
	tests/acceptance-test/src/test/java/suite/ProcessConfiguration.java
	tests/acceptance-test/src/test/java/suite/TestSuite.java
@codecov-io
Copy link

codecov-io commented Nov 1, 2019

Codecov Report

Merging #915 into master will decrease coverage by 0.02%.
The diff coverage is 99.26%.

Impacted file tree graph

@@             Coverage Diff              @@
##             master     #915      +/-   ##
============================================
- Coverage     99.36%   99.33%   -0.03%     
- Complexity     2097     2159      +62     
============================================
  Files           319      327       +8     
  Lines          5792     6053     +261     
  Branches        310      333      +23     
============================================
+ Hits           5755     6013     +258     
  Misses            5        5              
- Partials         32       35       +3
Impacted Files Coverage Δ Complexity Δ
...main/java/com/quorum/tessera/encryption/Nonce.java 100% <ø> (ø) 7 <0> (?)
.../java/com/quorum/tessera/encryption/Encryptor.java 100% <ø> (ø) 3 <0> (?)
.../quorum/tessera/encryption/EncryptorException.java 100% <ø> (ø) 1 <0> (?)
...m/quorum/tessera/data/EncryptedRawTransaction.java 96.77% <ø> (ø) 18 <0> (ø) ⬇️
.../java/com/quorum/tessera/config/ConfigFactory.java 100% <ø> (ø) 1 <0> (ø) ⬇️
.../quorum/tessera/enclave/RawTransactionBuilder.java 100% <ø> (ø) 6 <0> (ø) ⬇️
...um/tessera/key/generation/KeyGeneratorFactory.java 100% <ø> (ø) 1 <0> (ø) ⬇️
...ava/com/quorum/tessera/config/ConfigException.java 100% <ø> (ø) 1 <0> (ø) ⬇️
...va/com/quorum/tessera/encryption/KeyException.java 100% <ø> (ø) 1 <0> (?)
...va/com/quorum/tessera/nacl/jnacl/JnaclFactory.java 100% <100%> (ø) 4 <2> (+1) ⬆️
... and 53 more

Continue to review full report at Codecov.

Legend - Click here to learn more
Δ = absolute <relative> (impact), ø = not affected, ? = missing data
Powered by Codecov. Last update 73bd354...ee58618. Read the comment docs.

@melowe
Copy link
Contributor Author

melowe commented Nov 4, 2019

KeyPair config requires refactoring .

@melowe melowe closed this Nov 4, 2019
melowe and others added 6 commits November 5, 2019 12:00
Move password file generation out of config factory.
to be consumed by password resolver. Add tests to ensure that implicit
protocol using absence or presence of passwords or passwordFile elements
are still working as intended.
@melowe melowe reopened this Nov 7, 2019
@melowe melowe closed this Nov 8, 2019
@melowe melowe reopened this Nov 8, 2019
@melowe melowe marked this pull request as ready for review November 8, 2019 12:13
an array of values. Add tests for marshal and unmarshal. Ensure that
w3c element is also handled in xml adapter as unmarhsal receives a list 
of dom elements rather than jaxb elements.
@melowe melowe merged commit 84f0c34 into master Nov 19, 2019
@melowe melowe deleted the encryption_alt_curves branch November 19, 2019 10:40
@Krish1979 Krish1979 added 0.10.2 0.10.2 feature User features labels Dec 5, 2019
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
0.10.2 0.10.2 feature User features
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants