Skip to content
Snippets Groups Projects
Select Git revision
  • 53d506aa8708ef4a5bf7dc56c3debf2e69c84d98
  • master default protected
  • fix_picked_up_file_in_runtime_release
  • network/gtest-1000 protected
  • upgradable-multisig
  • runtime/gtest-1000
  • network/gdev-800 protected
  • cgeek/issue-297-cpu
  • gdev-800-tests
  • update-docker-compose-rpc-squid-names
  • fix-252
  • 1000i100-test
  • hugo/tmp-0.9.1
  • network/gdev-803 protected
  • hugo/endpoint-gossip
  • network/gdev-802 protected
  • hugo/distance-precompute
  • network/gdev-900 protected
  • tuxmain/anonymous-tx
  • debug/podman
  • hugo/195-doc
  • gtest-1000-0.11.1 protected
  • gtest-1000-0.11.0 protected
  • gtest-1000 protected
  • gdev-900-0.10.1 protected
  • gdev-900-0.10.0 protected
  • gdev-900-0.9.2 protected
  • gdev-800-0.8.0 protected
  • gdev-900-0.9.1 protected
  • gdev-900-0.9.0 protected
  • gdev-803 protected
  • gdev-802 protected
  • runtime-801 protected
  • gdev-800 protected
  • runtime-800-bis protected
  • runtime-800 protected
  • runtime-800-backup protected
  • runtime-701 protected
  • runtime-700 protected
  • runtime-600 protected
  • runtime-500 protected
41 results

README.md

Blame
  • save_binary_signed_message.py 1.96 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
    
    import libnacl.sign
    
    from duniterpy.key import SigningKey
    
    # CONFIG #######################################
    
    SIGNED_MESSAGE_FILENAME = "/tmp/duniter_signed_message.bin"
    
    ################################################
    
    
    def save_binary_signed_message():
        # prompt hidden user entry
        salt = getpass.getpass("Enter your passphrase (salt): ")
    
        # prompt hidden user entry
        password = getpass.getpass("Enter your password: ")
    
        # Create key object
        key = SigningKey.from_credentials(salt, password)
    
        # Display your public key
        print("Public key for your credentials: %s" % key.pubkey)
    
        message = input("Enter your message: ")
    
        # Sign the message, the signed string is the message itself plus the
        # signature
        signed_message = key.sign(bytes(message, "utf-8"))  # type: bytes
    
        # To create a verifier pass in the verify key:
        veri = libnacl.sign.Verifier(key.hex_vk())
        # Verify the message!
        verified = veri.verify(signed_message)
        print(f"Message verified: {verified}")
    
        # save signed message in a file
        with open(SIGNED_MESSAGE_FILENAME, "wb") as file_handler:
            file_handler.write(signed_message)
    
        print("Signed message saved in file ./{0}".format(SIGNED_MESSAGE_FILENAME))
    
    
    if __name__ == "__main__":
        save_binary_signed_message()