I am trying to create a plugin that adds a new IMAP capability. So far I have 
this:



const char *foo_plugin_version = DOVECOT_ABI_VERSION;

static struct module *foo_module;
static imap_client_created_func_t *next_hook_client_created;

static void foo_client_created(struct client **client)
{
    str_append((*client)->capability_string, " XFOO");

    if (next_hook_client_created != NULL) {
      next_hook_client_created(client);
    }
}

void foo_plugin_init(struct module *module)
{
  i_info(“init”);
  foo_module = module;
  next_hook_client_created = imap_client_created_hook_set(foo_client_created);
}

void foo_plugin_deinit(void)
{
  i_info(“deinit”);
  imap_client_created_hook_set(next_hook_client_created);
}

const char foo_plugin_binary_dependency[] = "imap”;



On Fedora 20, with the dovecot and dovecot-devel packages installed, I compile 
this with:

cc -Wall -shared -fPIC -DHAVE_CONFIG_H -I/usr/include/dovecot -o 
lib20_foo_plugin.so foo-plugin.c



And then install with:

sudo cp lib20_foo_plugin.so /usr/lib64/dovecot/

(I also have mail_plugin_dir = /usr/lib64/dovecot in 10-mail.conf)



I enable this plugin in /etc/dovecot/conf.d/20-imap.conf with:

protocol imap {
  mail_plugins = $mail_plugins foo
}


But … nothing happens. No warnings, no errors, no crashes.

How do I debug this? Am I missing something obvious?

Does the naming of the plugin matter?

 S.

Reply via email to