diff options
author | Nathan Kinder <nkinder@redhat.com> | 2009-12-15 14:16:04 -0800 |
---|---|---|
committer | Nathan Kinder <nkinder@redhat.com> | 2009-12-15 14:16:04 -0800 |
commit | cf0fcc51746c7e280ada377d37cdab318fd231e9 (patch) | |
tree | 9e126ecec5e170b6bc1a8ed94f5fa803bc889c1e /ldap/servers/slapd/pblock.c | |
parent | 24e6ca2262e1fa9114fb80b5d2f32205379d3a97 (diff) | |
download | ds-cf0fcc51746c7e280ada377d37cdab318fd231e9.tar.gz ds-cf0fcc51746c7e280ada377d37cdab318fd231e9.tar.xz ds-cf0fcc51746c7e280ada377d37cdab318fd231e9.zip |
Bug 518084 - Fix out of order retro changelog entries
When using the retro changelog plugin, post-op plugins that perform
internal operations (such as memberOf) can result in the internal
operation preceeding the original operation in the changelog.
The fix is to give the retro changelog a higher precedence than the
other post-op plugins. This required some core server changes to
be made around the plugin precedence to allow an object plugin to
pass it's precedence into it's calls to slapi_register_plugin()
when it registers other plugin types.
I added an update LDIF to set the plugin precedence when running
"setup-ds.pl -u". I also noticed an AVC when restarting after the
update due to the schema.bak directory that is created. I've
adjusted the dirsrv SELinux policy to deal with this AVC.
Diffstat (limited to 'ldap/servers/slapd/pblock.c')
-rw-r--r-- | ldap/servers/slapd/pblock.c | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/ldap/servers/slapd/pblock.c b/ldap/servers/slapd/pblock.c index da6ed8d8..88803777 100644 --- a/ldap/servers/slapd/pblock.c +++ b/ldap/servers/slapd/pblock.c @@ -460,6 +460,9 @@ slapi_pblock_get( Slapi_PBlock *pblock, int arg, void *value ) case SLAPI_PLUGIN_VERSION: (*(char **)value) = pblock->pb_plugin->plg_version; break; + case SLAPI_PLUGIN_PRECEDENCE: + (*(int *)value) = pblock->pb_plugin->plg_precedence; + break; case SLAPI_PLUGIN_OPRETURN: (*(int *)value) = pblock->pb_opreturn; break; @@ -1779,6 +1782,9 @@ slapi_pblock_set( Slapi_PBlock *pblock, int arg, void *value ) case SLAPI_PLUGIN_VERSION: pblock->pb_plugin->plg_version = (char *) value; break; + case SLAPI_PLUGIN_PRECEDENCE: + pblock->pb_plugin->plg_precedence = *((int *) value; + break; case SLAPI_PLUGIN_OPRETURN: pblock->pb_opreturn = *((int *) value); break; |