mirror of
https://github.com/strongswan/strongswan.git
synced 2025-10-04 00:00:14 -04:00
crypt-burn: Support burning signers
This commit is contained in:
parent
3935d812b7
commit
22d0c934cd
@ -124,6 +124,56 @@ static bool burn_aead(const proposal_token_t *token, u_int limit, u_int len)
|
|||||||
return ok;
|
return ok;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int burn_signer(const proposal_token_t *token, u_int limit, u_int len)
|
||||||
|
{
|
||||||
|
chunk_t key, data, sig;
|
||||||
|
signer_t *signer;
|
||||||
|
int i = 0;
|
||||||
|
bool ok;
|
||||||
|
|
||||||
|
signer = lib->crypto->create_signer(lib->crypto, token->algorithm);
|
||||||
|
if (!signer)
|
||||||
|
{
|
||||||
|
fprintf(stderr, "%N not supported\n",
|
||||||
|
integrity_algorithm_names, token->algorithm);
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
data = chunk_alloc(len);
|
||||||
|
memset(data.ptr, 0xDD, data.len);
|
||||||
|
key = chunk_alloc(signer->get_key_size(signer));
|
||||||
|
memset(key.ptr, 0xAA, key.len);
|
||||||
|
sig = chunk_alloc(signer->get_block_size(signer));
|
||||||
|
|
||||||
|
ok = signer->set_key(signer, key);
|
||||||
|
while (ok)
|
||||||
|
{
|
||||||
|
if (!signer->get_signature(signer, data, sig.ptr))
|
||||||
|
{
|
||||||
|
fprintf(stderr, "creating signature failed!\n");
|
||||||
|
ok = FALSE;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if (!signer->verify_signature(signer, data, sig))
|
||||||
|
{
|
||||||
|
fprintf(stderr, "verifying signature failed!\n");
|
||||||
|
ok = FALSE;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if (limit && ++i == limit)
|
||||||
|
{
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
signer->destroy(signer);
|
||||||
|
|
||||||
|
free(data.ptr);
|
||||||
|
free(key.ptr);
|
||||||
|
free(sig.ptr);
|
||||||
|
|
||||||
|
return ok;
|
||||||
|
}
|
||||||
|
|
||||||
int main(int argc, char *argv[])
|
int main(int argc, char *argv[])
|
||||||
{
|
{
|
||||||
const proposal_token_t *token;
|
const proposal_token_t *token;
|
||||||
@ -170,6 +220,9 @@ int main(int argc, char *argv[])
|
|||||||
ok = burn_crypter(token, limit, len);
|
ok = burn_crypter(token, limit, len);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
case INTEGRITY_ALGORITHM:
|
||||||
|
ok = burn_signer(token, limit, len);
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
fprintf(stderr, "'%s' is not a crypter/aead algorithm!\n", argv[1]);
|
fprintf(stderr, "'%s' is not a crypter/aead algorithm!\n", argv[1]);
|
||||||
ok = FALSE;
|
ok = FALSE;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user