[xmlsec] build system changes
Aleksey Sanin
aleksey@aleksey.com
Fri, 05 Sep 2003 01:09:19 -0700
> What about crypto lib to be loaded dynamically, i.e. xmlsec core to
> have "plugin architecture"?
If you really want to do it then you can do it already. I don't want to
go into "plugin" bussiness myself
because (IMHO):
- The main usage for xmlsec is on servers, most likely there would
be only one crypto
engine and nobody cares about plugins.
- It would be difficult to maintain (different OS have different
ways of loading shared libs).
- I don't think it's a good idea from security point of view to load
crypto engines as plugins.
I would love to see a use case when application would need to switch
crypot libraries "on the fly".
IMHO, crypto library is something you "just use" (of course, unless you
are an author of that library :) ).
> About packages ...
Ok, may be I was not clear about proposed changes. I would like to try
to explain again.
I want to:
1) Always build all available xmlsec-<crypto> libraries (it's not
the case on windows).
I hope the reaso.ns for that change are clear.
2) Always build all xmlsec-<crypto> command line tools and do a soft
link or copy
of the xmlsec-<default-crypto>(.exe) to xmlsec(.exe). This would
make everything backward
compatible and in the same time will provide an abillity to use,
say, xmlsec-openssl.exe
to test xmlsec-mscrypto.exe and produce both during one build. This
is also required for
next step.
3) Split current xmlsec and xmlsec-devel RPM packages into xmlsec,
xmlsec-devel,
xmlsec-openssl, xmlsec-openssl-devel. The reasons for that is that I
would like to have a more
symmetrical system. I.e. we already have xmlsec-nss and
xmlsec-nss-devel and
it's strange that there is no xmlsec-openssl and
xmlsec-openssl-devel. Also this would
give an NSS use who does not want to know about OpenSSL a way to use
xmlsec
w/o installing OpenSSL.
None of the changes above has any API or ABI modifications (except may
be the last one:
a user who installed just xmlsec packaged now would have to install
xmlsec and xmlsec-openssl).
> May be we should have some wrappers as example for certificate:
I don't want to make xmlsec a wrapper for crypto engines. My goal was to
create common API
for dealing with XML Security related stuff. For example, inside core
xmlsec I don't care how the
application/crypto library stores the key. I am only interested in
having non-null xmlSecKeyPtr :)
And I don't think it is really possible to find a simple and nice way to
wrap different crypto libs in
one API. Take a look at OpenSSL, NSS and MSCrypto APIs for dealing with
X509 certs store.
IMHO, mapping all of them into one common API is not a simple task and
one would always find
a reason to go and use native functions. For example, I am familiar with
a big cross-platform
client application that is based on a wxWindows library (which provides
unified wrapper API for
native GUI for Windows, Mac, GNOME/GTK, etc). wxWindows is a great
library and it has
everything needed for writing a cross-platform GUI code. Unfortunately,
this application still have
a lot of "#ifdef WX_WINDOWS" or "#ifdef WX_MAC" conditions because
- only Windows have registry and COM objects;
- Mac hides files starting with dot (".xxx") and user has no easy way
to access them;
- in GTK/GNOME only one thread can do GUI;
...
The list is huge and I would guess that total "common" GUI code in that
application is not more
than 60% of all GUI code. This is a great result that shows how
wxWindows simplify writing
cross-platform applications but it also shows that even very
sofisticated and complex "common
API wrapper" has its limitations.
Aleksey