@ -17,13 +17,13 @@
< P STYLE = "margin-bottom: 0in" > < FONT SIZE = 4 > Firebird plugins.< / FONT > < / P >
< P STYLE = "margin-bottom: 0in" > < FONT SIZE = 4 > Firebird plugins.< / FONT > < / P >
< P STYLE = "margin-bottom: 0in" > < BR >
< P STYLE = "margin-bottom: 0in" > < BR >
< / P >
< / P >
< P STYLE = "margin-bottom: 0in" > < FONT SIZE = 4 > Since version 3 f irebird
< P STYLE = "margin-bottom: 0in" > < FONT SIZE = 4 > Since version 3, F irebird
supports plugins architecture. This means that for a number of
supports plugins architecture. This means that for a number of
predefined points in firebird code user can write his own fragment of
predefined points in Firebird code, user can write his own fragment of
code which will be executed when needed. Plugin is not necessarily
code which will be executed when needed. Plugin is not necessarily
always written be user - f irebird already has a number of plugins
always written be user - F irebird already has a number of plugins
which are it' s native part. Moreover, as you will see later, some
which are its native part. Moreover, as you will see later, some
core parts of f irebird are implemented as plugins. < / FONT >
core parts of F irebird are implemented as plugins. < / FONT >
< / P >
< / P >
< P STYLE = "margin-bottom: 0in" > < BR >
< P STYLE = "margin-bottom: 0in" > < BR >
< / P >
< / P >
@ -39,7 +39,7 @@ related but different things. Plugin is used to name:</FONT></P>
library may contain code for more than one plugin;< / FONT > < / P >
library may contain code for more than one plugin;< / FONT > < / P >
< LI > < P STYLE = "margin-bottom: 0in" > < FONT SIZE = 4 > plugin's factory - an
< LI > < P STYLE = "margin-bottom: 0in" > < FONT SIZE = 4 > plugin's factory - an
object created by that code (pure virtual C++ class), creating
object created by that code (pure virtual C++ class), creating
plugin instances on f irebird request;< / FONT > < / P >
plugin instances on F irebird request;< / FONT > < / P >
< LI > < P STYLE = "margin-bottom: 0in" > < FONT SIZE = 4 > instance of plugin,
< LI > < P STYLE = "margin-bottom: 0in" > < FONT SIZE = 4 > instance of plugin,
created by factory.< / FONT > < / P >
created by factory.< / FONT > < / P >
< / UL >
< / UL >
@ -49,12 +49,12 @@ clarified explicitly.</FONT></P>
< P STYLE = "margin-bottom: 0in" > < BR >
< P STYLE = "margin-bottom: 0in" > < BR >
< / P >
< / P >
< P STYLE = "margin-bottom: 0in" > < FONT SIZE = 4 > One should not expect that
< P STYLE = "margin-bottom: 0in" > < FONT SIZE = 4 > One should not expect that
f irebird plugin architecture will make it possible to create any kind
F irebird plugin architecture will make it possible to create any kind
of plugin you want. To be able to have plugin (for example)
of plugin you want. To be able to have plugin (for example)
encrypting database on the disk f irebird code should be prepared for
encrypting database on the disk, F irebird code should be prepared for
it – must have a point from which plugin is called. I.e. each
it – must have a point from which plugin is called. I.e. each
version has a fixed set of plugins which are supported. To add one
version has a fixed set of plugins which are supported. To add one
more type first of all f irebird code should be modified. What DOES
more type, first of all F irebird code should be modified. What DOES
our plugin architecture – it helps to make both adding new types of
our plugin architecture – it helps to make both adding new types of
plugins and writing plugin code simple and as universal between
plugins and writing plugin code simple and as universal between
plugins as possible.< / FONT > < / P >
plugins as possible.< / FONT > < / P >
@ -71,7 +71,7 @@ set of plugin types:</FONT></P>
< LI > < P STYLE = "margin-bottom: 0in" > < FONT SIZE = 4 > ExternalEngine
< LI > < P STYLE = "margin-bottom: 0in" > < FONT SIZE = 4 > ExternalEngine
controls use of various engines, see README.external_routines;< / FONT > < / P >
controls use of various engines, see README.external_routines;< / FONT > < / P >
< LI > < P STYLE = "margin-bottom: 0in" > < FONT SIZE = 4 > Trace plugin is known
< LI > < P STYLE = "margin-bottom: 0in" > < FONT SIZE = 4 > Trace plugin is known
from f irebird 2.5, but a way how it interacts with engine was
from F irebird 2.5, but a way how it interacts with engine was
changed to match new generic rules; < / FONT >
changed to match new generic rules; < / FONT >
< / P >
< / P >
< LI > < P STYLE = "margin-bottom: 0in" > < FONT SIZE = 4 > encrypting plugins
< LI > < P STYLE = "margin-bottom: 0in" > < FONT SIZE = 4 > encrypting plugins
@ -87,8 +87,8 @@ set of plugin types:</FONT></P>
< P STYLE = "margin-bottom: 0in" > < BR >
< P STYLE = "margin-bottom: 0in" > < BR >
< / P >
< / P >
< P STYLE = "margin-bottom: 0in" > < FONT SIZE = 4 > Plugins are using a set of
< P STYLE = "margin-bottom: 0in" > < FONT SIZE = 4 > Plugins are using a set of
special f irebird interfaces (see README.interfaces about interfaces
special F irebird interfaces (see README.interfaces about interfaces
in f irebird). All plugin-specific interfaces are reference counted,
in F irebird). All plugin-specific interfaces are reference counted,
i.e. have explicitly controlled lifetime. Interfaces are declared in
i.e. have explicitly controlled lifetime. Interfaces are declared in
Plugin.h include file. There is a simple example of writing plugin
Plugin.h include file. There is a simple example of writing plugin
module – DbCrypt_example. It does not perform any actual encryption
module – DbCrypt_example. It does not perform any actual encryption
@ -105,14 +105,14 @@ short list of plugin features:</FONT></P>
attention to word “reasonable” - asking a question from plugin
attention to word “reasonable” - asking a question from plugin
at server's console is hardly good idea;< / FONT > < / P >
at server's console is hardly good idea;< / FONT > < / P >
< LI > < P STYLE = "margin-bottom: 0in" > < FONT SIZE = 4 > it's OK to use
< LI > < P STYLE = "margin-bottom: 0in" > < FONT SIZE = 4 > it's OK to use
f irebird API calls in your plugin if needed (for example, default
F irebird API calls in your plugin if needed (for example, default
authentication server and user manager are using f irebird database
authentication server and user manager are using F irebird database
to store accounts);< / FONT > < / P >
to store accounts);< / FONT > < / P >
< LI > < P STYLE = "margin-bottom: 0in" > < FONT SIZE = 4 > additionally f irebird
< LI > < P STYLE = "margin-bottom: 0in" > < FONT SIZE = 4 > additionally F irebird
provides a set of interfaces, helping you to configure your plugins
provides a set of interfaces, helping you to configure your plugins
(certainly, you are not forced to use them – plugin is generic
(certainly, you are not forced to use them – plugin is generic
code, which may use any way of providing configuration information,
code, which may use any way of providing configuration information,
but with standard tools you get common for the rest of f irebird
but with standard tools you get common for the rest of F irebird
configuration style and sooner of all save you efforts).< / FONT > < / P >
configuration style and sooner of all save you efforts).< / FONT > < / P >
< / UL >
< / UL >
< P STYLE = "margin-bottom: 0in" > < BR >
< P STYLE = "margin-bottom: 0in" > < BR >
@ -142,7 +142,7 @@ complicated.</FONT></P>
< P STYLE = "margin-bottom: 0in" > < BR >
< P STYLE = "margin-bottom: 0in" > < BR >
< / P >
< / P >
< P STYLE = "margin-bottom: 0in" > < FONT SIZE = 4 > As it was already
< P STYLE = "margin-bottom: 0in" > < FONT SIZE = 4 > As it was already
mentioned single plugin module may implement more than single plugin.
mentioned, single plugin module may implement more than single plugin.
Moreover, single plugin may have at the same time more than one
Moreover, single plugin may have at the same time more than one
configuration – and for each configuration separate plugin's
configuration – and for each configuration separate plugin's
factory is created. Each of this 3 objects (module – implementation
factory is created. Each of this 3 objects (module – implementation
@ -151,7 +151,7 @@ dynamic library. Plugin implementation's name is one given to it by
plugin developer and hard-coded inside module. Factory's name by
plugin developer and hard-coded inside module. Factory's name by
default equals to plugin implementation's name (and it's factory name
default equals to plugin implementation's name (and it's factory name
which is actually used in firebird.conf). Certainly in typical
which is actually used in firebird.conf). Certainly in typical
trivial case module contains one plugin, and that plugin works with
trivial case, module contains one plugin, and that plugin works with
only one configuration, and all 3 names are equal, and no more
only one configuration, and all 3 names are equal, and no more
configuration is needed – for example libEngine12.so or
configuration is needed – for example libEngine12.so or
Engine12.dll contains implementation of provider Engine12, and
Engine12.dll contains implementation of provider Engine12, and
@ -159,7 +159,7 @@ nothing else except record </FONT>
< / P >
< / P >
< P STYLE = "margin-bottom: 0in" > < FONT SIZE = 4 > Providers = Engine12< / FONT > < / P >
< P STYLE = "margin-bottom: 0in" > < FONT SIZE = 4 > Providers = Engine12< / FONT > < / P >
< P STYLE = "margin-bottom: 0in" > < FONT SIZE = 4 > in firebird.conf is needed
< P STYLE = "margin-bottom: 0in" > < FONT SIZE = 4 > in firebird.conf is needed
to load it. But if you have something complex – file h will help
to load it. But if you have something complex – file will help
you to have such plugin factories which you really want.< / FONT > < / P >
you to have such plugin factories which you really want.< / FONT > < / P >
< P STYLE = "margin-bottom: 0in" > < BR >
< P STYLE = "margin-bottom: 0in" > < BR >
< / P >
< / P >
@ -180,14 +180,14 @@ name of config record to be used</I></FONT></P>
## name of a file, containing plugin's configuration< / I > < / FONT > < / P >
## name of a file, containing plugin's configuration< / I > < / FONT > < / P >
< P STYLE = "margin-bottom: 0in" > < FONT SIZE = 4 > < I > }< / I > < / FONT > < / P >
< P STYLE = "margin-bottom: 0in" > < FONT SIZE = 4 > < I > }< / I > < / FONT > < / P >
< P STYLE = "margin-bottom: 0in" > < FONT SIZE = 4 > i.e. when plugin PlugName
< P STYLE = "margin-bottom: 0in" > < FONT SIZE = 4 > i.e. when plugin PlugName
is needed f irebird loads library LibName, finds in it plugin
is needed F irebird loads library LibName, finds in it plugin
registered with name RegName and passes it configuration from config
registered with name RegName and passes it configuration from config
record ConfName or config file ConfFile (config record is used if
record ConfName or config file ConfFile (config record is used if
bi th are given). Each parameter in this record may be missing, in
bo th are given). Each parameter in this record may be missing, in
that case the default PlugName is used. The only exception is
that case the default PlugName is used. The only exception is
ConfigFile – by default file with same name as module's dynamic
ConfigFile – by default, file with same name as module's dynamic
library but .conf extension is used. ConfigFile is expected to have
library but .conf extension is used. ConfigFile is expected to have
format Key=Value (like other f irebird configuration files), same
format Key=Value (like other F irebird configuration files), same
format is used for plugin record:< / FONT > < / P >
format is used for plugin record:< / FONT > < / P >
< P STYLE = "margin-bottom: 0in" > < FONT SIZE = 4 > < I > Config = ConfName< / I > < / FONT > < / P >
< P STYLE = "margin-bottom: 0in" > < FONT SIZE = 4 > < I > Config = ConfName< / I > < / FONT > < / P >
< P STYLE = "margin-bottom: 0in" > < FONT SIZE = 4 > < I > {< / I > < / FONT > < / P >
< P STYLE = "margin-bottom: 0in" > < FONT SIZE = 4 > < I > {< / I > < / FONT > < / P >
@ -203,8 +203,8 @@ vendor and others – from another one (and have different licenses
for appropriate client parts), but each vendor calls his plugin
for appropriate client parts), but each vendor calls his plugin
BestCrypt. Certainly, first of all you have to rename libraries to
BestCrypt. Certainly, first of all you have to rename libraries to
something like WC1 and WC2 – one can't have 2 files with same name
something like WC1 and WC2 – one can't have 2 files with same name
in one directory. But after it modules stop to load automatically –
in one directory. But after it, modules stop to load automatically –
they are not named BestCrypt any more. To fix it plugins.conf should
they are not named BestCrypt any more. To fix it, plugins.conf should
contain something like this:< / FONT > < / P >
contain something like this:< / FONT > < / P >
< P STYLE = "margin-bottom: 0in" > < FONT SIZE = 4 > < I > Plugin = WC1< / I > < / FONT > < / P >
< P STYLE = "margin-bottom: 0in" > < FONT SIZE = 4 > < I > Plugin = WC1< / I > < / FONT > < / P >
< P STYLE = "margin-bottom: 0in" > < FONT SIZE = 4 > < I > {< / I > < / FONT > < / P >
< P STYLE = "margin-bottom: 0in" > < FONT SIZE = 4 > < I > {< / I > < / FONT > < / P >
@ -227,7 +227,7 @@ automatically select appropriate plugin to talk to client.</FONT></P>
< P STYLE = "margin-bottom: 0in" > < BR >
< P STYLE = "margin-bottom: 0in" > < BR >
< / P >
< / P >
< P STYLE = "margin-bottom: 0in" > < FONT SIZE = 4 > Another sample may be
< P STYLE = "margin-bottom: 0in" > < FONT SIZE = 4 > Another sample may be
found in distributed with f irebird plugins.conf. One of standard
found in distributed with F irebird plugins.conf. One of standard
plugins, UDR, is written to use non-default configuration. Therefore
plugins, UDR, is written to use non-default configuration. Therefore
module name and one configuration parameter are given explicitly.< / FONT > < / P >
module name and one configuration parameter are given explicitly.< / FONT > < / P >
< P STYLE = "margin-bottom: 0in" > < BR >
< P STYLE = "margin-bottom: 0in" > < BR >
@ -241,7 +241,7 @@ with such names. How do they work?</FONT></P>
< P STYLE = "margin-bottom: 0in" > < FONT SIZE = 4 > A. That are so-called
< P STYLE = "margin-bottom: 0in" > < FONT SIZE = 4 > A. That are so-called
'built-in' plugins. They are built into fbclient library, and
'built-in' plugins. They are built into fbclient library, and
therefore are always present. Arrival of such plugins is due to old
therefore are always present. Arrival of such plugins is due to old
ability to distribute windows f irebird client as single dll. It was
ability to distribute windows F irebird client as single dll. It was
decided to keep such feature at least for a case when standard set of
decided to keep such feature at least for a case when standard set of
plugins is used.< / FONT > < / P >
plugins is used.< / FONT > < / P >
< P STYLE = "margin-bottom: 0in" > < BR >
< P STYLE = "margin-bottom: 0in" > < BR >
@ -250,7 +250,7 @@ plugins is used.</FONT></P>
and Arc4 plugins mean?< / FONT > < / P >
and Arc4 plugins mean?< / FONT > < / P >
< P STYLE = "margin-bottom: 0in" > < FONT SIZE = 4 > A. Srp implements Secure
< P STYLE = "margin-bottom: 0in" > < FONT SIZE = 4 > A. Srp implements Secure
Remote Passwords protocol which is default way of authenticating
Remote Passwords protocol which is default way of authenticating
users in f irebird 3. It has efficient password’ s length equal to 20
users in F irebird 3. It has efficient password’ s length equal to 20
bytes, resistant to most of attacks (including man in the middle) and
bytes, resistant to most of attacks (including man in the middle) and
does not require exchanging any keys between client and server to
does not require exchanging any keys between client and server to
work. Arc4 means Alleged RC4 - an implementation of RC4 cypher. The
work. Arc4 means Alleged RC4 - an implementation of RC4 cypher. The