Asignify

Jul 20, 2023

Yet another signify tool

Asignify tool is heavily inspired by signify used in OpenBSD. However, the main goal of this project is to define high level API for signing files, validating signatures and encrypting using public keys cryptography. Asignify is designed to be portable and self-contained with zero external dependencies. It uses blake2b as the hash function and ed25519 implementation from tweetnacl.

Key features

  • Zero dependencies libc and C compiler are likely required though, so it could be easily used in embedded systems.
  • Modern cryptography primitives ed25519, blake2 and sha512 namely.
  • Ability to encrypt files with the same keys using curve25519 based cryptobox.
  • Protecting secret keys by passwords using PBKDF2-BLAKE2 routine.
  • Asignify can convert ssh ed25519 private keys to the native format and verify signatures using just ssh ed25519 public keys without intermediate conversions.
  • Asignify provides high level API for application developers for signing, verifying, encrypting and keys generation.
  • All keys, signatures and encrypted files contain version information allowing to change cryptographical primitives in the future without loosing of backward compatibility.


Checkout these related ports:
  • Zzuf - Transparent application input fuzzer
  • Zlint - X.509 certificate linter
  • Zeronet - Decentralized websites using Bitcoin crypto and BitTorrent network
  • Zenmap - GUI frontend for the Nmap scanning utility
  • Zeek - System for detecting network intruders in real-time
  • Zaproxy - The OWASP zed attack proxy
  • Yubioath-desktop - GUI for displaying OATH codes with a Yubikey
  • Yubikey-personalization-gui - Graphical YubiKey personalization tool
  • Yubikey-manager-qt - Cross-platform application for configuring any YubiKey
  • Yubikey-agent - Seamless ssh-agent for YubiKeys
  • Yubico-piv-tool - Yubico PIV tool
  • Ylva - Command line password manager and file encryption program
  • Ykpers - Library and tool for personalization of Yubico's YubiKey
  • Ykclient - Yubico C client library
  • Yersinia - Layer 2 vulnerability scanner (switches, spanning tree, 802.1q ...)