1
0
Fork 0
mirror of https://github.com/pgpainless/pgpainless.git synced 2025-01-06 18:27:59 +01:00
Commit graph

157 commits

Author SHA1 Message Date
3c88bdde9b
Refactor keytype related classes 2020-12-08 20:02:41 +01:00
4550425609 Wip: Add more elliptic curves, support for {X,Ed}25519 2020-12-08 19:26:57 +01:00
980782e629
Remove deprecated class PGPKeyRing 2020-12-08 19:14:52 +01:00
db2e97b449
Fix some javadoc issues 2020-12-05 00:17:32 +01:00
451313d945
Fix checkstyle issues 2020-12-05 00:01:12 +01:00
1be3d4d7d8
Add documentation to KeyRingUtils 2020-12-03 22:46:59 +01:00
3173ddbc45
Add static factory methods for SecretKeyRingProtector implementations 2020-11-29 19:08:52 +01:00
935af80d14
Add some more utility methods 2020-11-29 19:06:49 +01:00
145fa8c83c
Move unlockSecretKey method to KeyRingUtils 2020-11-29 16:04:15 +01:00
d9d25ed6fb
Merge pull request #31 from wiktor-k/add-expiration
Add ability to modify expiration dates for keys
2020-11-29 15:45:10 +01:00
fa2615b434
Forgot to deprecate encryptor method 2020-11-29 15:35:34 +01:00
cc1e4601e3
replace create{Encryptor,Decryptor} methods with encryptAndOrSign,decryptAndOrVerify 2020-11-29 15:33:54 +01:00
Wiktor Kwapisiewicz
2a672aaf03
Add ability to change expiration date for the primary key 2020-11-27 17:11:56 +01:00
93abfd5517
SecretKeyRingEditor: Add revoke() shortcut method 2020-11-22 21:25:52 +01:00
c266adb5a5
Fix getExpirationDate method for keys without expiration 2020-11-22 21:07:14 +01:00
5ee17fac69
Deprecate PGPainless's PGPKeyRing 2020-11-22 20:49:07 +01:00
cae93022ad
Add KeyRingInfo class that helps to extract information about key rings 2020-11-22 20:48:09 +01:00
8305fcf0ee
Allow for revocation attributes to be passed in when revoking subkey directly 2020-11-20 12:19:45 +01:00
0edd8b616f
Add support for creating detached revocation certificates 2020-11-20 12:01:39 +01:00
5cdbb125b0
Refactoring: move KeyRingEditor to SecretKeyRingEditor in prep for more editor classes 2020-11-19 17:51:57 +01:00
9f95e7925b De-duplicate KeyPrinter class 2020-11-18 12:20:59 +01:00
4dd2b2f71a
Implement revoking subkeys for key-ids as well 2020-11-13 16:59:55 +01:00
4ed2cdaed9
Introduce UserId utility class 2020-11-13 15:59:28 +01:00
31844c5212
break for-loop of addUserId method when finding key 2020-11-13 15:11:33 +01:00
86c3487ad4
Some code cleanup 2020-11-13 15:08:37 +01:00
9b2ad24bda
Implement revocation of subkeys 2020-11-13 14:32:29 +01:00
b4967db1a2
Implement adding subkeys to keyrings 2020-11-10 17:25:35 +01:00
99a2fcf1c0
Simplify KeyType API 2020-11-07 18:24:12 +01:00
6159428c9a
Add support for deleting user-ids (untested) 2020-11-03 19:56:35 +01:00
92e2828885
Add support for deleting subKeys (untested) 2020-11-03 19:32:01 +01:00
2d899e0a3b
Allow adding user-ids to sub keys 2020-11-03 19:29:15 +01:00
7c102334ed
expand expression to simplify debugging 2020-10-30 13:30:04 +01:00
70ad4a274e
Change method name to toNoPassphrase() 2020-10-30 13:29:18 +01:00
8097a9d964
Passphrase.isEmpty: also check for validity 2020-10-30 12:31:52 +01:00
423a3f1354
Merge pull request #18 from wiktor-k/fix-empty-passphrase
Fix creating keys with `Passphrase.emptyPassphrase()`
2020-10-30 12:31:06 +01:00
04420f8dac
Extract secret key checksum algorithm into constant 2020-10-30 12:28:11 +01:00
Wiktor Kwapisiewicz
59fe53c594
Fix creating keys with Passphrase.emptyPassphrase()
Previously the code supplied `null` to BouncyCastle's
encryptor/decryptor builder's build method and that caused
NullPointerException to be thrown.

The fix checks if the passphrase is empty and omits the BouncyCastle
builder in that case.

Fixes #16.
2020-10-30 12:22:05 +01:00
Wiktor Kwapisiewicz
e30d0f6293
Remove RSA_SIGN and RSA_ENCRYPT as they are deprecated
This change removes two mechanisms that are deprecated in RFC 4880. The
spec explicitly mentions that "RSA Encrypt-Only (2) and RSA Sign-Only
are deprecated and SHOULD NOT be generated" [0].

The remaining RSA_GENERAL key type was renamed to just RSA for ease of
use for developers.

[0]: https://tools.ietf.org/html/rfc4880#section-9.1
2020-10-30 11:48:28 +01:00
cdd1bf4198
Add documentation and throw NotYetImplementedException in stubs 2020-10-29 15:15:13 +01:00
99af9e0171
Re-encrypting whole keyring successful 2020-10-25 20:43:09 +01:00
623c4c930d
Adding user-ids works 2020-10-25 19:54:03 +01:00
651a69c118
Work on the editing api 2020-10-23 16:44:21 +02:00
207c41d411
Add initial draft interface for a key editor API 2020-10-22 01:20:43 +02:00
f21231ad53
Trim user-ids 2020-10-20 23:23:25 +02:00
c06bedd656
Introduce SignatureType enum 2020-10-20 22:59:06 +02:00
1b389f678a
Fix checkstyle issues 2020-10-20 22:58:45 +02:00
9670e5ecb9
Prevent additional user-id from being equal to primary user-id 2020-10-20 22:14:56 +02:00
11e7bc69fc
Fix NPE by initializing the SignatureGenerator 2020-10-16 13:11:46 +02:00
8c30db9bf1
Wip: Allow for additional user-ids to be added 2020-10-16 12:46:58 +02:00
6a4fa47c12
Remove unused imports 2020-09-09 20:49:31 +02:00
2af60454f5
Add KeyRingProtectionSettings.secureDefaultSettings() factory method 2020-08-31 12:37:34 +02:00
20f32926bb
Add Passphrase.fromPassword() and PasswordBasedSecretKeyRingProtector.forKey() factory methods 2020-08-31 12:26:07 +02:00
7de04c2949
Add handy shortcut methods to the API 2020-08-24 16:57:14 +02:00
f10d698a09
Remove dependency on jetbrains annotations 2020-08-24 16:44:14 +02:00
4f6a7d2838
Fix checkstyle issues 2020-08-24 16:26:29 +02:00
848a7a428b
Add handy default methods for the API and add documentation 2020-08-24 16:00:23 +02:00
65b670740e Add support for detached signatures 2020-08-24 14:56:42 +02:00
0a3f688b23
Add documentation for openpgp4fpr fingerprint methods 2020-07-10 20:31:33 +02:00
46af22cc50
Add toUri/fromUri methods to OpenPgpV4Fingerprint 2020-07-10 18:17:29 +02:00
6c449b86af
Move charset utf8 to static constant 2020-07-10 18:16:22 +02:00
f108ccc30c
Fix compatibility with java8 2020-04-21 17:34:21 +02:00
9c1f6fc812
return null-cryptors for unprotected keys 2020-01-14 22:10:07 +01:00
4b61745c46
Add default constructor and fix condition 2020-01-14 22:09:13 +01:00
750d93b009
Easier generation of simple keys with password 2020-01-12 20:32:55 +01:00
db15a3e962
Fix XMPP key selection strategy by auto appending xmpp: if missing 2020-01-12 19:56:16 +01:00
09e0a5360d
Reuse MultiMap constructor of Whitelist selection strategy 2020-01-12 18:34:21 +01:00
8a2051904a
Further refactoring of KeyRingBuilder 2020-01-12 16:37:24 +01:00
81c3a471a7
Refactor KeyRingBuilder 2020-01-12 15:40:50 +01:00
79b04d1535
Refactor KeyRingReader 2020-01-12 13:11:10 +01:00
cd4bf1ef96
Rely on ProviderFactory for access to BouncyCastleProvider 2020-01-10 19:03:04 +01:00
ead54cb00b
Fix checkstyle issues 2020-01-10 18:46:31 +01:00
5134463883
Fix animalsniffer bugs! 2020-01-10 18:42:39 +01:00
b615ef74b0
Further refactoring of SignatureVerifyingInputStream 2020-01-10 18:31:43 +01:00
2902c81b6c
Simplify integrity protection assignment of resultBuilder 2020-01-10 18:31:27 +01:00
dd976b7319
Add hint about mutli assignment 2020-01-10 18:30:48 +01:00
db09a0ffbe
First Refactoring of DecryptionStreamFactory 2020-01-10 17:12:13 +01:00
be33206d03
Refactor SignatureVerifyingInputStream 2020-01-10 15:57:15 +01:00
ad070d0c34
Refactor EncryptionStream 2020-01-10 15:43:22 +01:00
530a22ba0e
Improve tests and add signatures to result 2020-01-10 15:12:04 +01:00
cbb9b00b88 Rename KeyFlag.fromInteger -> fromBitmask 2020-01-09 20:53:46 +01:00
8780d5a7b0 algorithm: Use ConcurrentHashMap instead of HashMap
Signed-off-by: Paul Schaub <vanitasvitae@fsfe.org>
2020-01-09 20:53:42 +01:00
2c816dd84c
Use ProviderFactory instead of 'BC' 2020-01-09 20:45:21 +01:00
9a9f706e83
Introduce ProviderFactory.
The goal is to become Provider-agnostic one day
2020-01-09 20:20:51 +01:00
ed440e4434
Make toString() @NonNull 2020-01-09 20:00:28 +01:00
e9b5e6278a
Use StandardCharsets.UTF_8 2020-01-09 20:00:17 +01:00
2e3a435d4e
Wildcard Selection Strategy: make inner classes static 2020-01-09 19:58:52 +01:00
6679c1bf3f
Passphrase.java do not use deprecated finalize() 2020-01-09 19:06:48 +01:00
Florian Schmaus
7690b542ab Add type parameters where possible 2019-07-28 12:28:55 +02:00
Florian Schmaus
9f062ebd79 Remove no longer reuired KeyRingSubKeyFix
since we are using BouncyCastle 1.62 now.
2019-07-28 12:28:55 +02:00
Florian Schmaus
8abea678ca Tune down the INFO logging, use debug log level where sensible
Libraries should usually stay silent if everything works as
expected. Most of the INFO log levels call sites of pgpainless
actually are more of debug log level call sites. Hence this commit
changes most of them to use a debug log level.
2019-04-18 08:19:19 +02:00
36c871f198
Allow different providers than BC 2019-04-02 21:11:16 +02:00
90649a5882
Degrade decryption stream loglevel to FINE 2019-03-16 16:26:22 +01:00
4a45b9d114
Add MultiMapTest 2018-08-21 15:27:06 +02:00
5cd87bd537
Fix MultiMap.remove() 2018-08-21 14:47:39 +02:00
fe52a7f398
Fix OpenPgpV4Fingerprint.getKeyId() 2018-08-17 17:28:17 +02:00
Florian Schmaus
cfab8a744d Properly close InputStream in SymmetricEncryptorDecryptor
Although it is possibly not strict required, it is always a good idea
to close streams even if the conrete implementation does not cause
resource leaks when not closed. After all, the implementation could
change at some point in the future.
2018-08-05 12:23:54 +02:00
Florian Schmaus
b6bb395e4f Add missing @Override to EncryptionBuilder 2018-08-05 12:23:24 +02:00
e9958bc620
Move And + Or selection strategies to util 2018-08-03 12:28:25 +02:00
b89d3562ac
Add @Nullable, @Nonnull annotations through findbugs 2018-07-31 20:09:16 +02:00
c8f3e3d116
add containsVerifiedSignatureFrom(OpenPgpV4Fingerprint) to OpenPgpMetadata 2018-07-26 16:40:26 +02:00