summaryrefslogtreecommitdiffstats
path: root/ldap/servers/slapd/pblock.c
diff options
context:
space:
mode:
authorNathan Kinder <nkinder@redhat.com>2009-12-15 14:16:04 -0800
committerNathan Kinder <nkinder@redhat.com>2009-12-15 14:16:04 -0800
commitcf0fcc51746c7e280ada377d37cdab318fd231e9 (patch)
tree9e126ecec5e170b6bc1a8ed94f5fa803bc889c1e /ldap/servers/slapd/pblock.c
parent24e6ca2262e1fa9114fb80b5d2f32205379d3a97 (diff)
downloadds-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.c6
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;