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

Refactor encryption logic to fix type-checking and improve tests (CryptoUtil 3/3) #6160

Conversation

nabla-c0d3
Copy link
Contributor

@nabla-c0d3 nabla-c0d3 commented Nov 7, 2021

Status

Ready.

Description of Changes

This is the last PR for refactoring CryptoUtil and fixing type-checking, as described in #5599.

More specifically:

  • It hides the low-level encryption and decryption methods (encrypt() and decrypt()) by making them private. Instead, only higher-level, public methods can be used such as encrypt_source_file(), decrypt_journalist_reply(), etc.
    • This makes it easier to understand the crypto-related code, and also to write/maintain it. Previously, it was easy to make a mistake when using encrypt() or decrypt(), for example by providing the wrong fingerprints.
  • It makes the test suite for the crypto-related code a bit more comprehensive. For example:
    • It ensures that encrypted data can only be decrypted by the specific keys that were the intended recipients. This is what uncovered the issue described in Disable caching of GPG passphrases in the GPG agent (CryptoUtil 1/3) #6174 .
    • It no longer imports the journalist secret key when setting up GPG for the test suite. Instead the secret key is imported (and then removed) in the specific tests that need it.

@nabla-c0d3 nabla-c0d3 changed the title Refactor key and encryption mgmt Finish refactoring of CryptoUtil: refactor key management and encryption Nov 7, 2021
@nabla-c0d3 nabla-c0d3 force-pushed the refactor-key-and-encryption-mgmt branch 2 times, most recently from 644e3e2 to adeb4a6 Compare November 8, 2021 01:19
_default_encryption_mgr: Optional["EncryptionManager"] = None


class EncryptionManager:
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Not sure about this name... open to changing it.

app.crypto_util = CryptoUtil(
securedrop_root=config.SECUREDROP_ROOT,
gpg_key_dir=config.GPG_KEY_DIR,
)
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The main goal of this PR: removing app.crypto_util.

securedrop_root=config.SECUREDROP_ROOT,
gpg_key_dir=config.GPG_KEY_DIR,
)
app.storage = Storage(config.STORE_DIR, config.TEMP_DIR)
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Storage no longer needs the config.JOURNALIST_KEY.

securedrop/source_app/main.py Show resolved Hide resolved
# where files and directories are sent to be securely deleted
self.__shredder_path = os.path.abspath(os.path.join(self.__storage_path, "../shredder"))
if not os.path.exists(self.__shredder_path):
os.makedirs(self.__shredder_path, mode=0o700)

# crash if we don't have a way to securely remove files
if not rm.check_secure_delete_capability():
raise AssertionError("Secure file deletion is not possible.")
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Moved from CryptoUtil to here.

@nabla-c0d3 nabla-c0d3 force-pushed the refactor-key-and-encryption-mgmt branch from adeb4a6 to c9578ac Compare November 13, 2021 21:47
@lgtm-com
Copy link

lgtm-com bot commented Nov 13, 2021

This pull request introduces 1 alert when merging 8f3c8e5 into f34565d - view on LGTM.com

new alerts:

  • 1 for Unused import

@nabla-c0d3 nabla-c0d3 force-pushed the refactor-key-and-encryption-mgmt branch from 69aba24 to 6132be7 Compare November 16, 2021 05:40
journalist_secret_key_path = Path(__file__).parent / "files" / "test_journalist_key.sec"
journalist_secret_key = journalist_secret_key_path.read_text()
gpg.import_keys(journalist_secret_key)

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Important change here: the journalist's private/secret key is no longer imported by default.

Having the journalist secret key available in GPG was making the test suite behave differently compared to web app. For example, data in tests could get decrypted using the journalist secret key instead of the expected source key.


The journalist secret key is removed at the end of this context manager in order to not impact
other decryption-related tests.
"""
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

import_journalist_private_key() can be used when the journalist secret key needs to be available for a specific test.

@nabla-c0d3 nabla-c0d3 changed the title Finish refactoring of CryptoUtil: refactor key management and encryption Finish refactoring of encryption logic to fix type-checking and improve tests (CryptoUtil 3/3) Nov 22, 2021
@nabla-c0d3 nabla-c0d3 changed the title Finish refactoring of encryption logic to fix type-checking and improve tests (CryptoUtil 3/3) Refactor encryption logic to fix type-checking and improve tests (CryptoUtil 3/3) Nov 22, 2021
@nabla-c0d3 nabla-c0d3 force-pushed the refactor-key-and-encryption-mgmt branch 2 times, most recently from 7bb4b3b to 8f39600 Compare November 22, 2021 06:38
@nabla-c0d3 nabla-c0d3 force-pushed the refactor-key-and-encryption-mgmt branch from 8f39600 to 9834cad Compare November 25, 2021 02:56
@nabla-c0d3 nabla-c0d3 force-pushed the refactor-key-and-encryption-mgmt branch 3 times, most recently from 4222ede to 7a6bb0f Compare December 10, 2021 20:25
# Reduce source GPG key length to speed up tests at the expense of security
with mock.patch.object(
EncryptionManager, "GPG_KEY_LENGTH", PropertyMock(return_value=1024)
):
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Moved from CryptoUtil to the test suite.


# And the source or anyone else is NOT able to decrypt the message
# For GPG 2.1+, a non-null passphrase _must_ be passed to decrypt()
assert not encryption_mgr._gpg.decrypt(encrypted_message, passphrase="test 123").ok
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Example of a new test that ensures that only the right user/key can decrypt some data.

@nabla-c0d3 nabla-c0d3 force-pushed the refactor-key-and-encryption-mgmt branch from 7a6bb0f to 859fbf1 Compare December 11, 2021 10:33
@@ -0,0 +1,351 @@
import typing
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Coverage report:

---------- coverage: platform linux, python 3.8.10-final-0 -----------
Name                                   Stmts   Miss Branch BrPart  Cover
------------------------------------------------------------------------
encryption.py                            123      9     28      4    91%

@nabla-c0d3
Copy link
Contributor Author

I ran the tests locally and also manually tested the app (make dev) - didn't run into any problems.

@nabla-c0d3 nabla-c0d3 force-pushed the refactor-key-and-encryption-mgmt branch from 859fbf1 to 6fa34d0 Compare December 11, 2021 10:45
@nabla-c0d3 nabla-c0d3 marked this pull request as ready for review December 11, 2021 11:03
@nabla-c0d3 nabla-c0d3 requested a review from a team as a code owner December 11, 2021 11:03
Copy link
Contributor

@zenmonkeykstop zenmonkeykstop left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

  • no issues found in code review
  • tests pass in staging env
  • upgrade scenario is successful and tests pass against upgrade env
  • manual tests of affected functionality look good.

LGTM, thanks for this!

@zenmonkeykstop zenmonkeykstop merged commit 6cb4578 into freedomofpress:develop Dec 17, 2021
@nabla-c0d3 nabla-c0d3 deleted the refactor-key-and-encryption-mgmt branch June 11, 2022 17:35
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants