Skip to content
Snippets Groups Projects
Select Git revision
  • 9e691bb5d93dcbc5973c65204cd69e41bf639844
  • main default protected
  • release/1.1
  • encrypt_comments
  • mnemonic_dewif
  • authors_rules
  • 0.14
  • rtd
  • 1.2.1 protected
  • 1.2.0 protected
  • 1.1.1 protected
  • 1.1.0 protected
  • 1.0.0 protected
  • 1.0.0rc1 protected
  • 1.0.0rc0 protected
  • 1.0.0-rc protected
  • 0.62.0 protected
  • 0.61.0 protected
  • 0.60.1 protected
  • 0.58.1 protected
  • 0.60.0 protected
  • 0.58.0 protected
  • 0.57.0 protected
  • 0.56.0 protected
  • 0.55.1 protected
  • 0.55.0 protected
  • 0.54.3 protected
  • 0.54.2 protected
28 results

load_encrypted_ascii_armor_message.py

Blame
  • load_encrypted_ascii_armor_message.py 1.75 KiB
    # Copyright  2014-2021 Vincent Texier <vit@free.fr>
    #
    # DuniterPy is free software: you can redistribute it and/or modify
    # it under the terms of the GNU General Public License as published by
    # the Free Software Foundation, either version 3 of the License, or
    # (at your option) any later version.
    #
    # DuniterPy is distributed in the hope that it will be useful,
    # but WITHOUT ANY WARRANTY; without even the implied warranty of
    # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
    # GNU General Public License for more details.
    #
    # You should have received a copy of the GNU General Public License
    # along with this program.  If not, see <http://www.gnu.org/licenses/>.
    
    import getpass
    
    from duniterpy.key import AsciiArmor, SigningKey
    
    # CONFIG #######################################
    
    ENCRYPTED_AA_MESSAGE_PATH = "/tmp/duniter_aa_encrypted_message.txt"
    
    ################################################
    
    
    def load_encrypted_ascii_armor_message():
        # Ask public key of the recipient
        pubkeyBase58 = input("Enter public key of the message issuer: ")
    
        # prompt hidden user entry
        salt = getpass.getpass("Enter your passphrase (salt): ")
    
        # prompt hidden user entry
        password = getpass.getpass("Enter your password: ")
    
        # init SigningKey instance
        signing_key = SigningKey.from_credentials(salt, password)
    
        # Load ascii armor encrypted message from a file
        with open(ENCRYPTED_AA_MESSAGE_PATH, "r") as file_handler:
            ascii_armor_block = file_handler.read()
    
        print(
            "Encrypted Ascii Armor Message loaded from file {0}".format(
                ENCRYPTED_AA_MESSAGE_PATH
            )
        )
    
        print(AsciiArmor.parse(ascii_armor_block, signing_key, [pubkeyBase58]))
    
    
    if __name__ == "__main__":
        load_encrypted_ascii_armor_message()