Exemplo n.º 1
0
int
rsa_sha1_sign(const struct rsa_private_key *key,
              struct sha1_ctx *hash,
              mpz_t s)
{
  if (pkcs1_rsa_sha1_encode(s, key->size, hash))
    {
      rsa_compute_root(key, s, s);
      return 1;
    }
  else
    {
      mpz_set_ui(s, 0);
      return 0;
    }
}
Exemplo n.º 2
0
int
rsa_sha1_verify(const struct rsa_public_key *key,
                struct sha1_ctx *hash,
                const mpz_t s)
{
  int res;
  mpz_t m;

  mpz_init(m);
  
  res = (pkcs1_rsa_sha1_encode(m, key->size, hash)
	 && _rsa_verify(key, m, s));
  
  mpz_clear(m);

  return res;
}
Exemplo n.º 3
0
int
rsa_sha1_verify(const struct rsa_public_key *key,
                struct sha1_ctx *hash,
                const mpz_t s)
{
  int res;
  mpz_t m;

  assert(key->size >= RSA_MINIMUM_N_OCTETS);
  mpz_init(m);
  
  pkcs1_rsa_sha1_encode(m, key->size - 1, hash);
  res = _rsa_verify(key, m, s);
  
  mpz_clear(m);

  return res;
}