blowfish: Use plugin features to properly register crypter

This commit is contained in:
Tobias Brunner 2013-06-07 18:57:15 +02:00
parent 8f49a8d0a6
commit e3bdf03af4
1 changed files with 13 additions and 8 deletions

View File

@ -1,6 +1,6 @@
/*
* Copyright (C) 2008 Martin Willi
* Copyright (C) 2009 Andreas Steffen
* Copyright (C) 2008 Martin Willi
* Hochschule fuer Technik Rapperswil
*
* This program is free software; you can redistribute it and/or modify it
@ -38,11 +38,20 @@ METHOD(plugin_t, get_name, char*,
return "blowfish";
}
METHOD(plugin_t, get_features, int,
private_blowfish_plugin_t *this, plugin_feature_t *features[])
{
static plugin_feature_t f[] = {
PLUGIN_REGISTER(CRYPTER, blowfish_crypter_create),
PLUGIN_PROVIDE(CRYPTER, ENCR_BLOWFISH, 0),
};
*features = f;
return countof(f);
}
METHOD(plugin_t, destroy, void,
private_blowfish_plugin_t *this)
{
lib->crypto->remove_crypter(lib->crypto,
(crypter_constructor_t)blowfish_crypter_create);
free(this);
}
@ -57,15 +66,11 @@ plugin_t *blowfish_plugin_create()
.public = {
.plugin = {
.get_name = _get_name,
.reload = (void*)return_false,
.get_features = _get_features,
.destroy = _destroy,
},
},
);
lib->crypto->add_crypter(lib->crypto, ENCR_BLOWFISH, get_name(this),
(crypter_constructor_t)blowfish_crypter_create);
return &this->public.plugin;
}