# This setting controls the actual module library to load. This config file might
# be installed by the package that installs this module library.
module: /usr/lib/my-pkcs11-module.so
+
+# This controls whether the module is required to successfully initialize. If 'yes', then
+# a failure to load or initialize this module will result in a p11-kit system failure.
+critical: no
</programlisting>
<para>User configuration file: <literal>~/.pkcs11/pkcs11.conf</literal></para>
# some custom non-standard initialization arguments, as NSS expects.
module: /usr/lib/libsoftokn3.so
x-init-reserved: configdir='sql:/home/test/.pki/nssdb' certPrefix='' keyPrefix='' secmod='socmod.db'
+critical: yes
</programlisting>
<variablelist>
<varlistentry>
<term>module:</term>
- <listitem><para>The absolute path to the PKCS#11 module to load.
- This should include an extension like <literal>.so</literal></para></listitem>
+ <listitem>
+ <para>The absolute path to the PKCS#11 module to load.
+ This should include an extension like <literal>.so</literal></para>
+ <para>If this value is blank, then the module will be ignored.
+ This can be used in the user configs to override loading of a module
+ specified in the system configuration.</para>
+ </listitem>
+ </varlistentry>
+ <varlistentry>
+ <term>critical:</term>
+ <listitem>
+ <para>Set to <literal>yes</literal> if the module is critical and
+ required to load. If a critical module fails to load or initialize,
+ then the loading process for all registered modules will abort and
+ return an error code.</para>
+ <para>This argument is optional and defaults to <literal>no</literal>.</para>
+ </listitem>
</varlistentry>
</variablelist>
return configs;
}
+
+int
+_p11_conf_parse_boolean (const char *string,
+ int default_value)
+{
+ if (!string)
+ return default_value;
+
+ if (strcmp (string, "yes") == 0) {
+ return 1;
+ } else if (strcmp (string, "no") == 0) {
+ return 0;
+ } else {
+ _p11_message ("invalid setting '%s' defaulting to '%s'",
+ default_value ? "yes" : "no");
+ return default_value;
+ }
+}
hashmap *config;
int mode;
CK_RV rv;
+ int critical;
if (gl.config)
return CKR_OK;
if (!hash_steal (configs, key, (void**)&name, (void**)&config))
assert (0 && "not reached");
+ /* Is this a critical module, should abort loading of others? */
+ critical = _p11_conf_parse_boolean (hash_get (config, "critical"), 0);
+
rv = take_config_and_load_module_unlocked (&name, &config);
/*
free (name);
hash_free (config);
- if (rv != CKR_OK) {
+ if (critical && rv != CKR_OK) {
+ _p11_message ("aborting initializationg because module '%s' was marked as critical");
hash_free (configs);
return rv;
}