| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360236123622363236423652366236723682369237023712372237323742375237623772378237923802381238223832384238523862387238823892390239123922393239423952396239723982399240024012402240324042405240624072408240924102411241224132414241524162417241824192420242124222423242424252426242724282429243024312432243324342435243624372438243924402441244224432444244524462447244824492450245124522453245424552456245724582459246024612462246324642465246624672468246924702471247224732474247524762477247824792480248124822483248424852486248724882489249024912492249324942495249624972498249925002501250225032504250525062507250825092510251125122513251425152516251725182519252025212522252325242525252625272528252925302531253225332534253525362537253825392540254125422543254425452546254725482549255025512552255325542555255625572558255925602561256225632564256525662567256825692570257125722573257425752576257725782579258025812582258325842585258625872588258925902591259225932594259525962597259825992600260126022603260426052606260726082609261026112612261326142615261626172618261926202621262226232624262526262627262826292630263126322633263426352636263726382639264026412642264326442645264626472648264926502651265226532654265526562657265826592660266126622663266426652666266726682669267026712672267326742675267626772678267926802681268226832684268526862687268826892690269126922693269426952696269726982699270027012702270327042705270627072708270927102711271227132714271527162717271827192720272127222723272427252726272727282729273027312732273327342735273627372738273927402741274227432744274527462747274827492750275127522753275427552756275727582759276027612762276327642765276627672768276927702771277227732774277527762777277827792780278127822783278427852786278727882789279027912792279327942795279627972798279928002801280228032804280528062807280828092810281128122813281428152816281728182819282028212822282328242825282628272828282928302831283228332834283528362837283828392840284128422843284428452846284728482849285028512852285328542855285628572858285928602861286228632864286528662867286828692870287128722873287428752876287728782879288028812882288328842885288628872888288928902891289228932894289528962897 |
- /** BEGIN COPYRIGHT BLOCK
- * Copyright (C) 2001 Sun Microsystems, Inc. Used by permission.
- * Copyright (C) 2005 Red Hat, Inc.
- * All rights reserved.
- *
- * License: GPL (version 3 or any later version).
- * See LICENSE for details.
- * END COPYRIGHT BLOCK **/
- #ifdef HAVE_CONFIG_H
- # include <config.h>
- #endif
- /* windows_private.c */
- #include "repl.h"
- #include "repl5.h"
- #include "slap.h"
- #include "slapi-plugin.h"
- #include "winsync-plugin.h"
- #include "windowsrepl.h"
- struct windowsprivate {
-
- Slapi_DN *windows_subtree; /* DN of synchronized subtree (on the windows side) */
- Slapi_DN *directory_subtree; /* DN of synchronized subtree on directory side */
- /* this simplifies the mapping as it's simply
- from the former to the latter container, or
- vice versa */
- ber_int_t dirsync_flags;
- ber_int_t dirsync_maxattributecount;
- char *dirsync_cookie;
- int dirsync_cookie_len;
- PRBool dirsync_cookie_has_more;
- PRBool create_users_from_dirsync;
- PRBool create_groups_from_dirsync;
- char *windows_domain;
- int isnt4;
- int iswin2k3;
- /* This filter is used to determine if an entry belongs to this agreement. We put it here
- * so we only have to allocate each filter once instead of doing it every time we receive a change. */
- Slapi_Filter *directory_filter; /* Used for checking if local entries need to be sync'd to AD */
- Slapi_Filter *windows_filter; /* Used for checking if remote entries need to be sync'd to DS */
- Slapi_Filter *deleted_filter; /* Used for checking if an entry is an AD tombstone */
- Slapi_Entry *raw_entry; /* "raw" un-schema processed last entry read from AD */
- int keep_raw_entry; /* flag to control when the raw entry is set */
- void *api_cookie; /* private data used by api callbacks */
- time_t sync_interval; /* how often to run the dirsync search, in seconds */
- int one_way; /* Indicates if this is a one-way agreement and which direction it is */
- int move_action; /* Indicates what to do with DS entry if AD entry is moved out of scope */
- Slapi_Entry *curr_entry; /* entry being retrieved; used for the range retrieval */
- char **range_attrs; /* next attributes for the range retrieval */
- char *windows_userfilter;
- char *directory_userfilter;
- struct subtreepair *subtree_pairs; /* Array of subtree pairs (winSyncSubtreePair) */
- Slapi_DN *windows_treetop; /* Common subtree top to sync on AD */
- /* If winSyncSubtreePair is not set, identical to windows_subtree.
- * If set, ancestor node of all AD subtrees. */
- Slapi_DN *directory_treetop; /* Common subtree top to sync on DS */
- /* If winSyncSubtreePair is not set, identical to directory_subtree.
- * If set, ancestor node of all DS subtrees. */
- };
- static void windows_private_set_windows_domain(const Repl_Agmt *ra, char *domain);
- static subtreePair *create_subtree_pairs(char **pairs);
- static void free_subtree_pairs(subtreePair **pairs);
- static int
- true_value_from_string(char *val)
- {
- if (strcasecmp (val, "on") == 0 || strcasecmp (val, "yes") == 0 ||
- strcasecmp (val, "true") == 0 || strcasecmp (val, "1") == 0)
- {
- return 1;
- } else
- {
- return 0;
- }
- }
- /* yech - can't declare a constant string array because type_nsds7XX variables
- are not constant strings - so have to build a lookup table */
- static int
- get_next_disallow_attr_type(int *ii, const char **type)
- {
- switch (*ii) {
- case 0: *type = type_nsds7WindowsReplicaArea; break;
- case 1: *type = type_nsds7DirectoryReplicaArea; break;
- case 2: *type = type_nsds7WindowsDomain; break;
- default: *type = NULL; break;
- }
- if (*type) {
- (*ii)++;
- return 1;
- }
- return 0;
- }
- static int
- check_update_allowed(Repl_Agmt *ra, const char *type, Slapi_Entry *e, int *retval)
- {
- int rc = 1;
- /* note - it is not an error to defer setting the value in the ra */
- *retval = 1;
- if (agmt_get_update_in_progress(ra)) {
- const char *distype = NULL;
- int ii = 0;
- while (get_next_disallow_attr_type(&ii, &distype)) {
- if (slapi_attr_types_equivalent(type, distype)) {
- char *tmpstr = slapi_entry_attr_get_charptr(e, type);
- slapi_log_error(SLAPI_LOG_REPL, windows_repl_plugin_name,
- "windows_parse_config_entry: setting %s to %s will be "
- "deferred until current update is completed\n",
- type, tmpstr);
- slapi_ch_free_string(&tmpstr);
- rc = 0;
- break;
- }
- }
- }
- return rc;
- }
- static int
- windows_parse_config_entry(Repl_Agmt *ra, const char *type, Slapi_Entry *e)
- {
- char *tmpstr = NULL;
- int retval = 0;
- if (!check_update_allowed(ra, type, e, &retval))
- {
- return retval;
- }
-
- /*
- * if winSyncSubtreePair is set, WindowsReplicaArea and DirectoryReplicaArea
- * are ignored.
- */
- if (type == NULL || slapi_attr_types_equivalent(type,type_nsds7WindowsReplicaArea))
- {
- tmpstr = slapi_entry_attr_get_charptr(e, type_nsds7WindowsReplicaArea);
- if (NULL != tmpstr)
- {
- windows_private_set_windows_subtree(ra, slapi_sdn_new_dn_passin(tmpstr) );
- }
- retval = 1;
- }
- if (type == NULL || slapi_attr_types_equivalent(type,type_nsds7DirectoryReplicaArea))
- {
- tmpstr = slapi_entry_attr_get_charptr(e, type_nsds7DirectoryReplicaArea);
- if (NULL != tmpstr)
- {
- windows_private_set_directory_subtree(ra, slapi_sdn_new_dn_passin(tmpstr) );
- }
- retval = 1;
- }
- if (type == NULL || slapi_attr_types_equivalent(type,type_nsds7CreateNewUsers))
- {
- tmpstr = slapi_entry_attr_get_charptr(e, type_nsds7CreateNewUsers);
- if (NULL != tmpstr && true_value_from_string(tmpstr))
- {
- windows_private_set_create_users(ra, PR_TRUE);
- }
- else
- {
- windows_private_set_create_users(ra, PR_FALSE);
- }
- slapi_ch_free((void**)&tmpstr);
- /* If protocol is NULL; the agreement is not started yet.
- * So, no need to notify. */
- if (agmt_get_protocol(ra)) {
- prot_notify_agmt_changed(agmt_get_protocol(ra), (char *)agmt_get_long_name(ra));
- }
- retval = 1;
- }
- if (type == NULL || slapi_attr_types_equivalent(type,type_nsds7CreateNewGroups))
- {
- tmpstr = slapi_entry_attr_get_charptr(e, type_nsds7CreateNewGroups);
- if (NULL != tmpstr && true_value_from_string(tmpstr))
- {
- windows_private_set_create_groups(ra, PR_TRUE);
- }
- else
- {
- windows_private_set_create_groups(ra, PR_FALSE);
- }
- slapi_ch_free((void**)&tmpstr);
- /* If protocol is NULL; the agreement is not started yet.
- * So, no need to notify. */
- if (agmt_get_protocol(ra)) {
- prot_notify_agmt_changed(agmt_get_protocol(ra), (char *)agmt_get_long_name(ra));
- }
- retval = 1;
- }
- if (type == NULL || slapi_attr_types_equivalent(type,type_nsds7WindowsDomain))
- {
- tmpstr = slapi_entry_attr_get_charptr(e, type_nsds7WindowsDomain);
- if (NULL != tmpstr)
- {
- windows_private_set_windows_domain(ra,tmpstr);
- }
- /* No need to free tmpstr because it was aliased by the call above */
- tmpstr = NULL;
- retval = 1;
- }
- if (type == NULL || slapi_attr_types_equivalent(type,type_winSyncInterval))
- {
- tmpstr = slapi_entry_attr_get_charptr(e, type_winSyncInterval);
- if (NULL != tmpstr)
- {
- windows_private_set_sync_interval(ra,tmpstr);
- /* If protocol is NULL; the agreement is not started yet.
- * So, no need to notify. */
- if (agmt_get_protocol(ra)) {
- prot_notify_agmt_changed(agmt_get_protocol(ra), (char *)agmt_get_long_name(ra));
- }
- }
- slapi_ch_free_string(&tmpstr);
- retval = 1;
- }
- if (type == NULL || slapi_attr_types_equivalent(type,type_oneWaySync))
- {
- tmpstr = slapi_entry_attr_get_charptr(e, type_oneWaySync);
- if (NULL != tmpstr)
- {
- if (strcasecmp(tmpstr, "fromWindows") == 0) {
- windows_private_set_one_way(ra, ONE_WAY_SYNC_FROM_AD);
- } else if (strcasecmp(tmpstr, "toWindows") == 0) {
- windows_private_set_one_way(ra, ONE_WAY_SYNC_TO_AD);
- } else {
- slapi_log_error(SLAPI_LOG_FATAL, windows_repl_plugin_name,
- "Ignoring illegal setting for %s attribute in replication "
- "agreement \"%s\". Valid values are \"toWindows\" or "
- "\"fromWindows\".\n", type_oneWaySync, slapi_entry_get_dn(e));
- windows_private_set_one_way(ra, ONE_WAY_SYNC_DISABLED);
- }
- }
- else
- {
- windows_private_set_one_way(ra, ONE_WAY_SYNC_DISABLED);
- }
- slapi_ch_free((void**)&tmpstr);
- /* If protocol is NULL; the agreement is not started yet.
- * So, no need to notify. */
- if (agmt_get_protocol(ra)) {
- prot_notify_agmt_changed(agmt_get_protocol(ra), (char *)agmt_get_long_name(ra));
- }
- retval = 1;
- }
- if (type == NULL || slapi_attr_types_equivalent(type,type_winsyncMoveAction))
- {
- tmpstr = slapi_entry_attr_get_charptr(e, type_winsyncMoveAction);
- if (NULL != tmpstr)
- {
- if (strcasecmp(tmpstr, "delete") == 0) {
- windows_private_set_move_action(ra, MOVE_DOES_DELETE);
- } else if (strcasecmp(tmpstr, "unsync") == 0) {
- windows_private_set_move_action(ra, MOVE_DOES_UNSYNC);
- } else if (strcasecmp(tmpstr, "none") == 0) {
- windows_private_set_move_action(ra, MOVE_DOES_NOTHING);
- } else {
- slapi_log_error(SLAPI_LOG_FATAL, windows_repl_plugin_name,
- "Ignoring illegal setting for %s attribute in replication "
- "agreement \"%s\". Valid values are \"delete\" or "
- "\"unsync\".\n", type_winsyncMoveAction, slapi_entry_get_dn(e));
- windows_private_set_move_action(ra, MOVE_DOES_NOTHING);
- }
- }
- else
- {
- windows_private_set_move_action(ra, MOVE_DOES_NOTHING);
- }
- slapi_ch_free((void**)&tmpstr);
- /* If protocol is NULL; the agreement is not started yet.
- * So, no need to notify. */
- if (agmt_get_protocol(ra)) {
- prot_notify_agmt_changed(agmt_get_protocol(ra), (char *)agmt_get_long_name(ra));
- }
- retval = 1;
- }
- if (type == NULL || slapi_attr_types_equivalent(type,type_winSyncWindowsFilter))
- {
- tmpstr = slapi_entry_attr_get_charptr(e, type_winSyncWindowsFilter);
- windows_private_set_windows_userfilter(ra, tmpstr); /* if NULL, set it */
- retval = 1;
- }
- if (type == NULL || slapi_attr_types_equivalent(type,type_winSyncDirectoryFilter))
- {
- tmpstr = slapi_entry_attr_get_charptr(e, type_winSyncDirectoryFilter);
- windows_private_set_directory_userfilter(ra, tmpstr); /* if NULL, set it */
- retval = 1;
- }
- if (type == NULL || slapi_attr_types_equivalent(type, type_winSyncSubtreePair))
- {
- char **parray = slapi_entry_attr_get_charray(e, type_winSyncSubtreePair);
- /* If winSyncSubtreePair is not set, subtree_pairs is NULL */
- windows_private_set_subtreepairs(ra, parray);
- slapi_ch_array_free(parray);
- retval = 1;
- }
- windows_private_set_windows_treetop(ra, NULL);
- windows_private_set_directory_treetop(ra, NULL);
- return retval;
- }
- /* Returns non-zero if the modify was ok, zero if not */
- int
- windows_handle_modify_agreement(Repl_Agmt *ra, const char *type, Slapi_Entry *e)
- {
- /* Is this a Windows agreement ? */
- if (get_agmt_agreement_type(ra) == REPLICA_TYPE_WINDOWS)
- {
- return windows_parse_config_entry(ra,type,e);
- } else
- {
- return 0;
- }
- }
- void
- windows_update_done(Repl_Agmt *agmt, int is_total)
- {
- /* "flush" the changes made during the update to the agmt */
- /* get the agmt entry */
- Slapi_DN *agmtdn = slapi_sdn_dup(agmt_get_dn_byref(agmt));
- Slapi_Entry *agmte = NULL;
- int rc = slapi_search_internal_get_entry(agmtdn, NULL, &agmte,
- repl_get_plugin_identity (PLUGIN_MULTIMASTER_REPLICATION));
- if ((rc == 0) && agmte) {
- int ii = 0;
- const char *distype = NULL;
- while (get_next_disallow_attr_type(&ii, &distype)) {
- windows_handle_modify_agreement(agmt, distype, agmte);
- }
- }
- slapi_entry_free(agmte);
- slapi_sdn_free(&agmtdn);
- }
- void
- windows_init_agreement_from_entry(Repl_Agmt *ra, Slapi_Entry *e)
- {
- agmt_set_priv(ra,windows_private_new());
- windows_parse_config_entry(ra,NULL,e);
- windows_plugin_init(ra);
- }
- const char* windows_private_get_purl(const Repl_Agmt *ra)
- {
- const char* windows_purl;
- char *hostname;
- hostname = agmt_get_hostname(ra);
- if(slapi_is_ipv6_addr(hostname)){
- /* need to put brackets around the ipv6 address */
- windows_purl = slapi_ch_smprintf("ldap://[%s]:%d", hostname, agmt_get_port(ra));
- } else {
- windows_purl = slapi_ch_smprintf("ldap://%s:%d", hostname, agmt_get_port(ra));
- }
- slapi_ch_free_string(&hostname);
- return windows_purl;
- }
- Dirsync_Private* windows_private_new()
- {
- Dirsync_Private *dp;
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "=> windows_private_new\n" );
- dp = (Dirsync_Private *)slapi_ch_calloc(sizeof(Dirsync_Private),1);
- dp->dirsync_maxattributecount = -1;
- dp->directory_filter = NULL;
- dp->windows_filter = NULL;
- dp->deleted_filter = NULL;
- dp->sync_interval = PERIODIC_DIRSYNC_INTERVAL;
- dp->windows_userfilter = NULL;
- dp->directory_userfilter = NULL;
- dp->subtree_pairs = NULL;
- dp->windows_treetop = NULL;
- dp->directory_treetop = NULL;
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "<= windows_private_new\n" );
- return dp;
- }
- void windows_agreement_delete(Repl_Agmt *ra)
- {
- const subtreePair *sp;
- Dirsync_Private *dp = (Dirsync_Private *) agmt_get_priv(ra);
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "=> windows_private_delete\n" );
- PR_ASSERT(dp != NULL);
-
- winsync_plugin_call_destroy_agmt_cb(ra, dp->directory_subtree,
- dp->windows_subtree);
- windows_plugin_cleanup_agmt(ra);
- slapi_sdn_free(&dp->directory_subtree);
- slapi_sdn_free(&dp->windows_subtree);
- slapi_filter_free(dp->directory_filter, 1);
- slapi_filter_free(dp->windows_filter, 1);
- slapi_filter_free(dp->deleted_filter, 1);
- slapi_entry_free(dp->raw_entry);
- slapi_ch_free_string(&dp->windows_domain);
- dp->raw_entry = NULL;
- dp->api_cookie = NULL;
- slapi_ch_free_string(&dp->dirsync_cookie);
- dp->dirsync_cookie_len = 0;
- slapi_ch_free_string(&dp->windows_userfilter);
- slapi_ch_free_string(&dp->directory_userfilter);
- slapi_sdn_free((Slapi_DN **)&dp->windows_treetop);
- slapi_sdn_free((Slapi_DN **)&dp->directory_treetop);
- for (sp = dp->subtree_pairs; sp && sp->ADsubtree && sp->DSsubtree; sp++) {
- slapi_sdn_free((Slapi_DN **)&sp->ADsubtree);
- slapi_sdn_free((Slapi_DN **)&sp->DSsubtree);
- }
- slapi_ch_free((void **)&dp->subtree_pairs);
- slapi_ch_free((void **)&dp);
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "<= windows_private_delete\n" );
- }
- int windows_private_get_isnt4(const Repl_Agmt *ra)
- {
- Dirsync_Private *dp;
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "=> windows_private_get_isnt4\n" );
- PR_ASSERT(ra);
- dp = (Dirsync_Private *) agmt_get_priv(ra);
- PR_ASSERT (dp);
-
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "<= windows_private_get_isnt4\n" );
- return dp->isnt4;
- }
- void windows_private_set_isnt4(const Repl_Agmt *ra, int isit)
- {
- Dirsync_Private *dp;
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "=> windows_private_set_isnt4\n" );
- PR_ASSERT(ra);
- dp = (Dirsync_Private *) agmt_get_priv(ra);
- PR_ASSERT (dp);
- dp->isnt4 = isit;
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "<= windows_private_set_isnt4\n" );
- }
- int windows_private_get_iswin2k3(const Repl_Agmt *ra)
- {
- Dirsync_Private *dp;
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "=> windows_private_get_iswin2k3\n" );
- PR_ASSERT(ra);
- dp = (Dirsync_Private *) agmt_get_priv(ra);
- PR_ASSERT (dp);
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "<= windows_private_get_iswin2k3\n" );
- return dp->iswin2k3;
- }
- void windows_private_set_iswin2k3(const Repl_Agmt *ra, int isit)
- {
- Dirsync_Private *dp;
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "=> windows_private_set_iswin2k3\n" );
- PR_ASSERT(ra);
- dp = (Dirsync_Private *) agmt_get_priv(ra);
- PR_ASSERT (dp);
- dp->iswin2k3 = isit;
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "<= windows_private_set_iswin2k3\n" );
- }
- /* Returns a copy of the Slapi_Filter pointer. The caller should not free it */
- Slapi_Filter* windows_private_get_directory_filter(const Repl_Agmt *ra)
- {
- Dirsync_Private *dp;
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "=> windows_private_get_directory_filter\n" );
- PR_ASSERT(ra);
- dp = (Dirsync_Private *) agmt_get_priv(ra);
- PR_ASSERT (dp);
- if (dp->directory_filter == NULL) {
- char *string_filter = NULL;
- const char *userfilter = windows_private_get_directory_userfilter(ra);
- if (userfilter) {
- if ('(' == *userfilter) {
- string_filter = slapi_ch_smprintf("(&(|(objectclass=ntuser)(objectclass=ntgroup))(ntUserDomainId=*)%s)",
- userfilter);
- } else {
- string_filter = slapi_ch_smprintf("(&(|(objectclass=ntuser)(objectclass=ntgroup))(ntUserDomainId=*)(%s))",
- userfilter);
- }
- } else {
- string_filter = slapi_ch_strdup("(&(|(objectclass=ntuser)(objectclass=ntgroup))(ntUserDomainId=*))");
- }
- /* The filter gets freed in windows_agreement_delete() */
- dp->directory_filter = slapi_str2filter( string_filter );
- slapi_ch_free_string(&string_filter);
- }
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "<= windows_private_get_directory_filter\n" );
- return dp->directory_filter;
- }
- /* Returns a copy of the Slapi_Filter pointer. The caller should not free it */
- Slapi_Filter*
- windows_private_get_windows_filter(const Repl_Agmt *ra)
- {
- Dirsync_Private *dp;
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "=> windows_private_get_windows_filter\n" );
- PR_ASSERT(ra);
- dp = (Dirsync_Private *) agmt_get_priv(ra);
- PR_ASSERT (dp);
- if (dp->windows_filter == NULL) {
- const char *userfilter = windows_private_get_windows_userfilter(ra);
- if (userfilter) {
- char *string_filter = NULL;
- if ('(' == *userfilter) {
- string_filter = slapi_ch_strdup(userfilter);
- } else {
- string_filter = slapi_ch_smprintf("(%s)", userfilter);
- }
- /* The filter gets freed in windows_agreement_delete() */
- dp->windows_filter = slapi_str2filter( string_filter );
- slapi_ch_free_string(&string_filter);
- }
- }
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "<= windows_private_get_windows_filter\n" );
- return dp->windows_filter;
- }
- /* Returns a copy of the Slapi_Filter pointer. The caller should not free it */
- Slapi_Filter* windows_private_get_deleted_filter(const Repl_Agmt *ra)
- {
- Dirsync_Private *dp;
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "=> windows_private_get_deleted_filter\n" );
- PR_ASSERT(ra);
- dp = (Dirsync_Private *) agmt_get_priv(ra);
- PR_ASSERT (dp);
- if (dp->deleted_filter == NULL) {
- char *string_filter = slapi_ch_strdup("(isdeleted=*)");
- /* The filter gets freed in windows_agreement_delete() */
- dp->deleted_filter = slapi_str2filter( string_filter );
- slapi_ch_free_string(&string_filter);
- }
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "<= windows_private_get_deleted_filter\n" );
- return dp->deleted_filter;
- }
- /* Returns a copy of the Slapi_DN pointer, no need to free it */
- const Slapi_DN* windows_private_get_windows_subtree (const Repl_Agmt *ra)
- {
- Dirsync_Private *dp;
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "=> windows_private_get_windows_subtree\n" );
- PR_ASSERT(ra);
- dp = (Dirsync_Private *) agmt_get_priv(ra);
- PR_ASSERT (dp);
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "<= windows_private_get_windows_subtree\n" );
- return dp->windows_subtree;
- }
- const char *
- windows_private_get_windows_domain(const Repl_Agmt *ra)
- {
- Dirsync_Private *dp;
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "=> windows_private_get_windows_domain\n" );
- PR_ASSERT(ra);
- dp = (Dirsync_Private *) agmt_get_priv(ra);
- PR_ASSERT (dp);
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "<= windows_private_get_windows_domain\n" );
- return dp->windows_domain;
- }
- static void
- windows_private_set_windows_domain(const Repl_Agmt *ra, char *domain)
- {
- Dirsync_Private *dp;
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "=> windows_private_set_windows_domain\n" );
- PR_ASSERT(ra);
- dp = (Dirsync_Private *) agmt_get_priv(ra);
- PR_ASSERT (dp);
- slapi_ch_free_string(&dp->windows_domain);
- dp->windows_domain = domain;
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "<= windows_private_set_windows_domain\n" );
- }
- /* Returns a copy of the Slapi_DN pointer, no need to free it */
- const Slapi_DN* windows_private_get_directory_subtree (const Repl_Agmt *ra)
- {
- Dirsync_Private *dp;
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "=> windows_private_get_directory_replarea\n" );
- PR_ASSERT(ra);
- dp = (Dirsync_Private *) agmt_get_priv(ra);
- PR_ASSERT (dp);
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "<= windows_private_get_directory_replarea\n" );
- return dp->directory_subtree;
- }
- /* Takes a copy of the sdn passed in */
- void windows_private_set_windows_subtree (const Repl_Agmt *ra,Slapi_DN* sdn )
- {
- Dirsync_Private *dp;
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "=> windows_private_set_windows_replarea\n" );
- PR_ASSERT(ra);
- PR_ASSERT(sdn);
- dp = (Dirsync_Private *) agmt_get_priv(ra);
- PR_ASSERT (dp);
- slapi_sdn_free(&dp->windows_subtree);
- dp->windows_subtree = sdn;
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "<= windows_private_set_windows_replarea\n" );
- }
- /* Takes a copy of the sdn passed in */
- void windows_private_set_directory_subtree (const Repl_Agmt *ra,Slapi_DN* sdn )
- {
- Dirsync_Private *dp;
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "=> windows_private_set_directory_replarea\n" );
- PR_ASSERT(ra);
- PR_ASSERT(sdn);
- dp = (Dirsync_Private *) agmt_get_priv(ra);
- PR_ASSERT (dp);
-
- slapi_sdn_free(&dp->directory_subtree);
- dp->directory_subtree = sdn;
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "<= windows_private_set_directory_replarea\n" );
- }
- PRBool windows_private_create_users(const Repl_Agmt *ra)
- {
- Dirsync_Private *dp;
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "=> windows_private_create_users\n" );
- PR_ASSERT(ra);
- dp = (Dirsync_Private *) agmt_get_priv(ra);
- PR_ASSERT (dp);
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "<= windows_private_create_users\n" );
- return dp->create_users_from_dirsync;
- }
- void windows_private_set_create_users(const Repl_Agmt *ra, PRBool value)
- {
- Dirsync_Private *dp;
-
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "=> windows_private_set_create_users\n" );
- PR_ASSERT(ra);
- dp = (Dirsync_Private *) agmt_get_priv(ra);
- PR_ASSERT (dp);
- dp->create_users_from_dirsync = value;
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "<= windows_private_set_create_users\n" );
- }
- PRBool windows_private_create_groups(const Repl_Agmt *ra)
- {
- Dirsync_Private *dp;
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "=> windows_private_create_groups\n" );
- PR_ASSERT(ra);
- dp = (Dirsync_Private *) agmt_get_priv(ra);
- PR_ASSERT (dp);
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "<= windows_private_create_groups\n" );
- return dp->create_groups_from_dirsync;
- }
- void windows_private_set_create_groups(const Repl_Agmt *ra, PRBool value)
- {
- Dirsync_Private *dp;
-
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "=> windows_private_set_create_groups\n" );
- PR_ASSERT(ra);
- dp = (Dirsync_Private *) agmt_get_priv(ra);
- PR_ASSERT (dp);
- dp->create_groups_from_dirsync = value;
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "<= windows_private_set_create_groups\n" );
- }
- int windows_private_get_one_way(const Repl_Agmt *ra)
- {
- Dirsync_Private *dp;
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "=> windows_private_get_one_way\n" );
- PR_ASSERT(ra);
- dp = (Dirsync_Private *) agmt_get_priv(ra);
- PR_ASSERT (dp);
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "<= windows_private_get_one_way\n" );
- return dp->one_way;
- }
- void windows_private_set_one_way(const Repl_Agmt *ra, int value)
- {
- Dirsync_Private *dp;
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "=> windows_private_set_one_way\n" );
- PR_ASSERT(ra);
- dp = (Dirsync_Private *) agmt_get_priv(ra);
- PR_ASSERT (dp);
- dp->one_way = value;
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "<= windows_private_set_one_way\n" );
- }
- const char*
- windows_private_get_windows_userfilter(const Repl_Agmt *ra)
- {
- Dirsync_Private *dp;
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "=> windows_private_get_windows_userfilter\n" );
- PR_ASSERT(ra);
- dp = (Dirsync_Private *) agmt_get_priv(ra);
- PR_ASSERT (dp);
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "<= windows_private_get_windows_userfilter\n" );
- return dp->windows_userfilter;
- }
- /* filter is passed in */
- void
- windows_private_set_windows_userfilter(const Repl_Agmt *ra, char *filter)
- {
- Dirsync_Private *dp;
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "=> windows_private_set_windows_userfilter\n" );
- PR_ASSERT(ra);
- dp = (Dirsync_Private *) agmt_get_priv(ra);
- PR_ASSERT (dp);
- slapi_ch_free_string(&dp->windows_userfilter);
- dp->windows_userfilter = filter;
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "<= windows_private_set_windows_userfilter\n" );
- }
- const char*
- windows_private_get_directory_userfilter(const Repl_Agmt *ra)
- {
- Dirsync_Private *dp;
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "=> windows_private_get_directory_userfilter\n" );
- PR_ASSERT(ra);
- dp = (Dirsync_Private *) agmt_get_priv(ra);
- PR_ASSERT (dp);
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "<= windows_private_get_directory_userfilter\n" );
- return dp->directory_userfilter;
- }
- /* filter is passed in */
- void
- windows_private_set_directory_userfilter(const Repl_Agmt *ra, char *filter)
- {
- Dirsync_Private *dp;
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "=> windows_private_set_directory_userfilter\n" );
- PR_ASSERT(ra);
- dp = (Dirsync_Private *) agmt_get_priv(ra);
- PR_ASSERT (dp);
- slapi_ch_free_string(&dp->directory_userfilter);
- dp->directory_userfilter = filter;
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "<= windows_private_set_directory_userfilter\n" );
- }
- const subtreePair*
- windows_private_get_subtreepairs(const Repl_Agmt *ra)
- {
- Dirsync_Private *dp;
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "=> windows_private_get_subtreepairs\n" );
- PR_ASSERT(ra);
- dp = (Dirsync_Private *) agmt_get_priv(ra);
- PR_ASSERT (dp);
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "<= windows_private_get_subtreepairs\n" );
- return dp->subtree_pairs;
- }
- /* parray is NOT passed in; caller frees it. */
- void
- windows_private_set_subtreepairs(const Repl_Agmt *ra, char **parray)
- {
- Dirsync_Private *dp;
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "=> windows_private_set_subtreepairs\n" );
- PR_ASSERT(ra);
- dp = (Dirsync_Private *) agmt_get_priv(ra);
- PR_ASSERT (dp);
- free_subtree_pairs(&(dp->subtree_pairs));
- dp->subtree_pairs = create_subtree_pairs(parray);
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "<= windows_private_set_subtreepairs\n" );
- }
- /*
- * winSyncSubtreePair: <DS_SUBTREE>:<WINDOWS_SUBTREE>
- * E.g.,
- * winSyncSubtreePair: ou=people,dc=example,dc=com:CN=users,DC=example,DC=com
- * winSyncSubtreePair: ou=adminpeople,dc=example,dc=com:CN=adminusers,DC=example,DC=com
- */
- static subtreePair *
- create_subtree_pairs(char **pairs)
- {
- subtreePair *subtree_pairs = NULL;
- subtreePair *spp;
- char **ptr;
- char *p0, *p1;
- char *saveptr = NULL;
- int cnt;
- for (cnt = 0, ptr = pairs; ptr && *ptr; cnt++, ptr++) ;
- if (0 == cnt) {
- return NULL;
- }
- subtree_pairs = (subtreePair *)slapi_ch_calloc(cnt + 1, sizeof(subtreePair));
- spp = subtree_pairs;
- for (ptr = pairs; ptr && *ptr; ptr++) {
- p0 = ldap_utf8strtok_r(*ptr, ":", &saveptr);
- p1 = ldap_utf8strtok_r(NULL, ":", &saveptr);
- if ((NULL == p0) || (NULL == p1)) {
- LDAPDebug1Arg(LDAP_DEBUG_ANY,
- "create_subtree_pairs: "
- "Ignoring invalid subtree pairs \"%s\".\n", *ptr);
- continue;
- }
- spp->DSsubtree = slapi_sdn_new_dn_byval(p0);
- if (NULL == spp->DSsubtree) {
- LDAPDebug1Arg(LDAP_DEBUG_ANY,
- "create_subtree_pairs: "
- "Ignoring invalid DS subtree \"%s\".\n",
- p0);
- continue;
- }
- spp->ADsubtree = slapi_sdn_new_dn_byval(p1);
- if (NULL == spp->ADsubtree) {
- LDAPDebug1Arg(LDAP_DEBUG_ANY,
- "create_subtree_pairs: "
- "Ignoring invalid AD subtree \"%s\".\n",
- p1);
- slapi_sdn_free(&(spp->DSsubtree));
- continue;
- }
- spp++;
- }
- return subtree_pairs;
- }
- static void
- free_subtree_pairs(subtreePair **pairs)
- {
- subtreePair *p;
- if (NULL == pairs) {
- return;
- }
- /*
- * If exists, the subtree pair is both non-NULL or NULL.
- * Both NULL is the condition to stop the loop.
- */
- for (p = *pairs; p && p->ADsubtree && p->DSsubtree; p++) {
- slapi_sdn_free(&(p->ADsubtree));
- slapi_sdn_free(&(p->DSsubtree));
- }
- slapi_ch_free((void **)pairs);
- }
- const Slapi_DN*
- windows_private_get_windows_treetop(const Repl_Agmt *ra)
- {
- Dirsync_Private *dp;
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "=> windows_private_get_windows_treetop\n" );
- PR_ASSERT(ra);
- dp = (Dirsync_Private *) agmt_get_priv(ra);
- PR_ASSERT (dp);
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "<= windows_private_get_windows_treetop\n" );
- return dp->windows_treetop;
- }
- /* treetop is NOT passed in */
- void
- windows_private_set_windows_treetop(const Repl_Agmt *ra, char *treetop)
- {
- Dirsync_Private *dp;
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "=> windows_private_set_windows_treetop\n" );
- PR_ASSERT(ra);
- dp = (Dirsync_Private *) agmt_get_priv(ra);
- PR_ASSERT (dp);
- slapi_sdn_free(&(dp->windows_treetop));
- if (treetop) {
- dp->windows_treetop = slapi_sdn_new_dn_byval(treetop);
- } else {
- const subtreePair *subtree_pairs = windows_private_get_subtreepairs(ra);
- const subtreePair *sp;
- if (subtree_pairs) {
- Slapi_DN *treetop_sdn = NULL;
- for (sp = subtree_pairs; sp && sp->ADsubtree; sp++) {
- if (NULL == treetop_sdn) {
- treetop_sdn = slapi_sdn_dup(sp->ADsubtree);
- } else {
- Slapi_DN *prev = treetop_sdn;
- treetop_sdn = slapi_sdn_common_ancestor(prev, sp->ADsubtree);
- slapi_sdn_free(&prev);
- }
- }
- if (treetop_sdn) {
- dp->windows_treetop = treetop_sdn;
- } else {
- LDAPDebug0Args(LDAP_DEBUG_ANY,
- "windows_private_set_windows_treetop: "
- "winSyncSubtreePair contains inconsistent Windows subtrees.\n");
- dp->windows_treetop = NULL;
- }
- } else {
- const Slapi_DN *windows_subtree = windows_private_get_windows_subtree(ra);
- dp->windows_treetop = slapi_sdn_dup(windows_subtree);
- }
- }
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "<= windows_private_set_windows_treetop\n" );
- }
- const Slapi_DN*
- windows_private_get_directory_treetop(const Repl_Agmt *ra)
- {
- Dirsync_Private *dp;
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "=> windows_private_get_directory_treetop\n" );
- PR_ASSERT(ra);
- dp = (Dirsync_Private *) agmt_get_priv(ra);
- PR_ASSERT (dp);
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "<= windows_private_get_directory_treetop\n" );
- return dp->directory_treetop;
- }
- /* treetop is NOT passed in */
- void
- windows_private_set_directory_treetop(const Repl_Agmt *ra, char *treetop)
- {
- Dirsync_Private *dp;
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "=> windows_private_set_directory_treetop\n" );
- PR_ASSERT(ra);
- dp = (Dirsync_Private *) agmt_get_priv(ra);
- PR_ASSERT (dp);
- slapi_sdn_free(&(dp->directory_treetop));
- if (treetop) {
- dp->directory_treetop = slapi_sdn_new_dn_byval(treetop);
- } else {
- const subtreePair *subtree_pairs = windows_private_get_subtreepairs(ra);
- if (subtree_pairs) {
- const subtreePair *sp;
- Slapi_DN *treetop_sdn = NULL;
- for (sp = subtree_pairs; sp && sp->DSsubtree; sp++) {
- if (NULL == treetop_sdn) {
- treetop_sdn = slapi_sdn_dup(sp->DSsubtree);
- } else {
- Slapi_DN *prev = treetop_sdn;
- treetop_sdn = slapi_sdn_common_ancestor(prev, sp->DSsubtree);
- slapi_sdn_free(&prev);
- }
- }
- if (treetop_sdn) {
- dp->directory_treetop = treetop_sdn;
- } else {
- LDAPDebug0Args(LDAP_DEBUG_ANY,
- "windows_private_set_directory_treetop: "
- "winSyncSubtreePair contains inconsistent Windows subtrees.\n");
- dp->directory_treetop = NULL;
- }
- } else {
- const Slapi_DN *directory_subtree = windows_private_get_directory_subtree(ra);
- dp->directory_treetop = slapi_sdn_dup(directory_subtree);
- }
- }
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "<= windows_private_set_directory_treetop\n" );
- }
- /*
- This function returns the current Dirsync_Private that's inside
- Repl_Agmt ra as a ldap control.
- */
- LDAPControl* windows_private_dirsync_control(const Repl_Agmt *ra)
- {
- LDAPControl *control = NULL;
- BerElement *ber;
- Dirsync_Private *dp;
- char iscritical = PR_TRUE;
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "=> windows_private_dirsync_control\n" );
-
- PR_ASSERT(ra);
-
- dp = (Dirsync_Private *) agmt_get_priv(ra);
- PR_ASSERT (dp);
- ber = ber_alloc();
- ber_printf( ber, "{iio}", dp->dirsync_flags, dp->dirsync_maxattributecount, dp->dirsync_cookie ? dp->dirsync_cookie : "", dp->dirsync_cookie_len );
- /* Use a regular directory server instead of a real AD - for testing */
- if (getenv("WINSYNC_USE_DS")) {
- iscritical = PR_FALSE;
- }
- slapi_build_control( REPL_DIRSYNC_CONTROL_OID, ber, iscritical, &control);
- ber_free(ber,1);
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "<= windows_private_dirsync_control\n" );
- return control;
- }
- /*
- This function scans the array of controls and updates the Repl_Agmt's
- Dirsync_Private if the dirsync control is found.
- */
- void windows_private_update_dirsync_control(const Repl_Agmt *ra,LDAPControl **controls )
- {
- Dirsync_Private *dp;
- int foundDirsyncControl;
- int i;
- LDAPControl *dirsync = NULL;
- BerElement *ber = NULL;
- ber_int_t hasMoreData;
- ber_int_t maxAttributeCount;
- BerValue *serverCookie = NULL;
- #ifdef FOR_DEBUGGING
- int return_value = LDAP_SUCCESS;
- #endif
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "=> windows_private_update_dirsync_control\n" );
- PR_ASSERT(ra);
- dp = (Dirsync_Private *) agmt_get_priv(ra);
- PR_ASSERT (dp);
-
- if (NULL != controls )
- {
- foundDirsyncControl = 0;
- for ( i = 0; (( controls[i] != NULL ) && ( !foundDirsyncControl )); i++ ) {
- foundDirsyncControl = !strcmp( controls[i]->ldctl_oid, REPL_DIRSYNC_CONTROL_OID );
- }
- if ( !foundDirsyncControl )
- {
- #ifdef FOR_DEBUGGING
- return_value = LDAP_CONTROL_NOT_FOUND;
- #endif
- goto choke;
- }
- else if (!controls[i-1]->ldctl_value.bv_val) {
- #ifdef FOR_DEBUGGING
- return_value = LDAP_CONTROL_NOT_FOUND;
- #endif
- goto choke;
- }
- else
- {
- dirsync = slapi_dup_control( controls[i-1]);
- }
- if (!dirsync || !BV_HAS_DATA((&(dirsync->ldctl_value)))) {
- #ifdef FOR_DEBUGGING
- return_value = LDAP_CONTROL_NOT_FOUND;
- #endif
- goto choke;
- }
-
- ber = ber_init( &dirsync->ldctl_value ) ;
- if (ber_scanf( ber, "{iiO}", &hasMoreData, &maxAttributeCount, &serverCookie) == LBER_ERROR)
- {
- #ifdef FOR_DEBUGGING
- return_value = LDAP_CONTROL_NOT_FOUND;
- #endif
- goto choke;
- }
- slapi_ch_free_string(&dp->dirsync_cookie);
- dp->dirsync_cookie = ( char* ) slapi_ch_malloc(serverCookie->bv_len + 1);
- memcpy(dp->dirsync_cookie, serverCookie->bv_val, serverCookie->bv_len);
- dp->dirsync_cookie_len = (int) serverCookie->bv_len; /* XXX shouldn't cast? */
- /* dp->dirsync_maxattributecount = maxAttributeCount; We don't need to keep this */
- dp->dirsync_cookie_has_more = hasMoreData;
- choke:
- ber_bvfree(serverCookie);
- ber_free(ber,1);
- ldap_control_free(dirsync);
- }
- else
- {
- #ifdef FOR_DEBUGGING
- return_value = LDAP_CONTROL_NOT_FOUND;
- #endif
- }
- #ifdef FOR_DEBUGGING
- LDAPDebug1Arg( LDAP_DEBUG_TRACE, "<= windows_private_update_dirsync_control: rc=%d\n", return_value);
- #else
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "<= windows_private_update_dirsync_control\n" );
- #endif
- }
- PRBool windows_private_dirsync_has_more(const Repl_Agmt *ra)
- {
- Dirsync_Private *dp;
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "=> windows_private_dirsync_has_more\n" );
- PR_ASSERT(ra);
- dp = (Dirsync_Private *) agmt_get_priv(ra);
- PR_ASSERT (dp);
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "<= windows_private_dirsync_has_more\n" );
- return dp->dirsync_cookie_has_more;
- }
- void windows_private_null_dirsync_cookie(const Repl_Agmt *ra)
- {
- Dirsync_Private *dp;
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "=> windows_private_null_dirsync_control\n" );
- dp = (Dirsync_Private *) agmt_get_priv(ra);
- PR_ASSERT (dp);
- dp->dirsync_cookie_len = 0;
- slapi_ch_free_string(&dp->dirsync_cookie);
- dp->dirsync_cookie = NULL;
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "<= windows_private_null_dirsync_control\n" );
- }
- static
- Slapi_Mods *windows_private_get_cookie_mod(Dirsync_Private *dp, int modtype)
- {
- Slapi_Mods *smods = NULL;
- smods = slapi_mods_new();
- slapi_mods_add( smods, modtype,
- "nsds7DirsyncCookie", dp->dirsync_cookie_len , dp->dirsync_cookie);
- return smods;
- }
- /* writes the current cookie into dse.ldif under the replication agreement entry
- returns: ldap result code of the operation. */
- int
- windows_private_save_dirsync_cookie(const Repl_Agmt *ra)
- {
- Dirsync_Private *dp = NULL;
- Slapi_PBlock *pb = NULL;
- Slapi_DN* sdn = NULL;
- int rc = 0;
- Slapi_Mods *mods = NULL;
-
-
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "=> windows_private_save_dirsync_cookie\n" );
- PR_ASSERT(ra);
- dp = (Dirsync_Private *) agmt_get_priv(ra);
- PR_ASSERT (dp);
- pb = slapi_pblock_new ();
-
- mods = windows_private_get_cookie_mod(dp, LDAP_MOD_REPLACE);
- sdn = slapi_sdn_dup( agmt_get_dn_byref(ra) );
- slapi_modify_internal_set_pb_ext (pb, sdn,
- slapi_mods_get_ldapmods_byref(mods), NULL, NULL,
- repl_get_plugin_identity(PLUGIN_MULTIMASTER_REPLICATION), 0);
- slapi_modify_internal_pb (pb);
- slapi_pblock_get(pb, SLAPI_PLUGIN_INTOP_RESULT, &rc);
- if (rc == LDAP_NO_SUCH_ATTRIBUTE)
- { /* try again, but as an add instead */
- slapi_mods_free(&mods);
- mods = windows_private_get_cookie_mod(dp, LDAP_MOD_ADD);
- slapi_modify_internal_set_pb_ext (pb, sdn,
- slapi_mods_get_ldapmods_byref(mods), NULL, NULL,
- repl_get_plugin_identity(PLUGIN_MULTIMASTER_REPLICATION), 0);
- slapi_modify_internal_pb (pb);
-
- slapi_pblock_get(pb, SLAPI_PLUGIN_INTOP_RESULT, &rc);
- }
- slapi_pblock_destroy (pb);
- slapi_mods_free(&mods);
- slapi_sdn_free(&sdn);
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "<= windows_private_save_dirsync_cookie\n" );
- return rc;
- }
- /* reads the cookie in dse.ldif to the replication agreement entry
- returns: ldap result code of ldap operation, or
- LDAP_NO_SUCH_ATTRIBUTE. (this is the equilivent of a null cookie) */
- int windows_private_load_dirsync_cookie(const Repl_Agmt *ra)
- {
- Dirsync_Private *dp = NULL;
- Slapi_PBlock *pb = NULL;
-
- Slapi_DN* sdn = NULL;
- int rc = 0;
- Slapi_Entry *entry = NULL;
- Slapi_Attr *attr = NULL;
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "=> windows_private_load_dirsync_cookie\n" );
- PR_ASSERT(ra);
- dp = (Dirsync_Private *) agmt_get_priv(ra);
- PR_ASSERT (dp);
- pb = slapi_pblock_new ();
- sdn = slapi_sdn_dup( agmt_get_dn_byref(ra) );
-
- rc = slapi_search_internal_get_entry(sdn, NULL, &entry,
- repl_get_plugin_identity (PLUGIN_MULTIMASTER_REPLICATION));
- if (rc == 0)
- {
- rc= slapi_entry_attr_find( entry, type_nsds7DirsyncCookie, &attr );
- if (attr)
- {
- struct berval **vals;
- rc = slapi_attr_get_bervals_copy(attr, &vals );
-
- if (vals)
- {
- dp->dirsync_cookie_len = (int) (vals[0])->bv_len;
- slapi_ch_free_string(&dp->dirsync_cookie);
- dp->dirsync_cookie = ( char* ) slapi_ch_malloc(dp->dirsync_cookie_len + 1);
- memcpy(dp->dirsync_cookie,(vals[0]->bv_val), (vals[0])->bv_len+1);
- }
- ber_bvecfree(vals);
- /* we do not free attr */
- }
- else
- {
- rc = LDAP_NO_SUCH_ATTRIBUTE;
- }
- }
- if (entry)
- {
- slapi_entry_free(entry);
- }
-
- slapi_sdn_free( &sdn);
- slapi_pblock_destroy (pb);
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "<= windows_private_load_dirsync_cookie\n" );
- return rc;
- }
- /* get returns a pointer to the structure - do not free */
- Slapi_Entry *windows_private_get_raw_entry(const Repl_Agmt *ra)
- {
- Dirsync_Private *dp;
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "=> windows_private_get_raw_entry\n" );
- dp = (Dirsync_Private *) agmt_get_priv(ra);
- PR_ASSERT (dp);
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "<= windows_private_get_raw_entry\n" );
- return dp->raw_entry;
- }
- /* this is passin - windows_private owns the pointer, not a copy */
- void windows_private_set_raw_entry(const Repl_Agmt *ra, Slapi_Entry *e)
- {
- Dirsync_Private *dp;
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "=> windows_private_set_raw_entry\n" );
- dp = (Dirsync_Private *) agmt_get_priv(ra);
- PR_ASSERT (dp);
- /* If the keep raw entry flag is set, just free the passed
- * in entry and leave the current raw entry in place. */
- if (windows_private_get_keep_raw_entry(ra)) {
- slapi_entry_free(e);
- } else {
- slapi_entry_free(dp->raw_entry);
- dp->raw_entry = e;
- }
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "<= windows_private_set_raw_entry\n" );
- }
- /* Setting keep to 1 will cause the current raw entry to remain, even if
- * windows_private_set_raw_entry() is called. This behavior will persist
- * until this flag is set back to 0. */
- void windows_private_set_keep_raw_entry(const Repl_Agmt *ra, int keep)
- {
- Dirsync_Private *dp;
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "=> windows_private_set_keep_raw_entry\n" );
- dp = (Dirsync_Private *) agmt_get_priv(ra);
- PR_ASSERT (dp);
- dp->keep_raw_entry = keep;
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "<= windows_private_set_keep_raw_entry\n" );
- }
- int windows_private_get_keep_raw_entry(const Repl_Agmt *ra)
- {
- Dirsync_Private *dp;
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "=> windows_private_get_keep_raw_entry\n" );
- dp = (Dirsync_Private *) agmt_get_priv(ra);
- PR_ASSERT (dp);
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "<= windows_private_get_keep_raw_entry\n" );
- return dp->keep_raw_entry;
- }
- void *windows_private_get_api_cookie(const Repl_Agmt *ra)
- {
- Dirsync_Private *dp;
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "=> windows_private_get_api_cookie\n" );
- dp = (Dirsync_Private *) agmt_get_priv(ra);
- PR_ASSERT (dp);
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "<= windows_private_get_api_cookie\n" );
- return dp->api_cookie;
- }
- void windows_private_set_api_cookie(Repl_Agmt *ra, void *api_cookie)
- {
- Dirsync_Private *dp;
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "=> windows_private_set_api_cookie\n" );
- dp = (Dirsync_Private *) agmt_get_priv(ra);
- PR_ASSERT (dp);
- dp->api_cookie = api_cookie;
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "<= windows_private_set_api_cookie\n" );
- }
- time_t
- windows_private_get_sync_interval(const Repl_Agmt *ra)
- {
- Dirsync_Private *dp;
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "=> windows_private_get_sync_interval\n" );
- PR_ASSERT(ra);
- dp = (Dirsync_Private *) agmt_get_priv(ra);
- PR_ASSERT (dp);
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "<= windows_private_get_sync_interval\n" );
- return dp->sync_interval;
- }
- void
- windows_private_set_sync_interval(Repl_Agmt *ra, char *str)
- {
- Dirsync_Private *dp;
- time_t tmpval = 0;
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "=> windows_private_set_sync_interval\n" );
- PR_ASSERT(ra);
- dp = (Dirsync_Private *) agmt_get_priv(ra);
- PR_ASSERT (dp);
- if (str && (tmpval = (time_t)atol(str))) {
- dp->sync_interval = tmpval;
- }
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "<= windows_private_set_sync_interval\n" );
- }
- int
- windows_private_get_move_action(const Repl_Agmt *ra)
- {
- Dirsync_Private *dp;
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "=> windows_private_get_move_action\n" );
- PR_ASSERT(ra);
- dp = (Dirsync_Private *) agmt_get_priv(ra);
- PR_ASSERT (dp);
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "<= windows_private_get_move_action\n" );
- return dp->move_action;
- }
- void
- windows_private_set_move_action(const Repl_Agmt *ra, int value)
- {
- Dirsync_Private *dp;
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "=> windows_private_set_move_action\n" );
- PR_ASSERT(ra);
- dp = (Dirsync_Private *) agmt_get_priv(ra);
- PR_ASSERT (dp);
- dp->move_action = value;
- LDAPDebug0Args( LDAP_DEBUG_TRACE, "<= windows_private_set_move_action\n" );
- }
- static PRCallOnceType winsync_callOnce = {0,0};
- struct winsync_plugin {
- struct winsync_plugin *next; /* see PRCList - declare here to avoid lots of casting */
- struct winsync_plugin *prev; /* see PRCList - declare here to avoid lots of casting */
- void **api; /* the api - array of function pointers */
- int maxapi; /* the max index i.e. the api version */
- int precedence; /* lower number == higher precedence */
- };
- static struct winsync_plugin winsync_plugin_list;
- #define DECL_WINSYNC_API_IDX_FUNC(theapi,idx,maxidx,thetype,thefunc) \
- thetype thefunc = (theapi && (idx <= maxidx) && theapi[idx]) ? \
- (thetype)theapi[idx] : NULL;
- #define WINSYNC_PLUGIN_CALL_PLUGINS_BEGIN(idx,thetype,thefunc) \
- struct winsync_plugin *elem; \
- for (elem = PR_LIST_HEAD(&winsync_plugin_list); \
- elem && (elem != &winsync_plugin_list); \
- elem = PR_NEXT_LINK(elem)) { \
- DECL_WINSYNC_API_IDX_FUNC(elem->api,idx,elem->maxapi,thetype,thefunc); \
- if (thefunc) {
- #define WINSYNC_PLUGIN_CALL_PLUGINS_COOKIE_BEGIN(idx,thetype,thefunc) \
- WINSYNC_PLUGIN_CALL_PLUGINS_BEGIN(idx,thetype,thefunc) \
- void *cookie = winsync_plugin_cookie_find(ra, elem->api);
- #define WINSYNC_PLUGIN_CALL_PLUGINS_END } /* this one matches if thefunc */ } /* this one matches the for loop */
- /* this structure is per agreement - to store the cookie per agreement
- for each winsync plugin */
- struct winsync_plugin_cookie {
- struct winsync_plugin_cookie *next; /* see PRCList - declare here to avoid lots of casting */
- struct winsync_plugin_cookie *prev; /* see PRCList - declare here to avoid lots of casting */
- void **api; /* the api - array of function pointers */
- void *cookie; /* plugin data */
- };
- static struct winsync_plugin *
- new_winsync_plugin(void **theapi, int maxapi, int precedence)
- {
- struct winsync_plugin *wpi = (struct winsync_plugin *)slapi_ch_calloc(1, sizeof(struct winsync_plugin));
- wpi->api = theapi;
- wpi->maxapi = maxapi;
- wpi->precedence = precedence;
- return wpi;
- }
- static struct winsync_plugin *
- windows_plugin_find(void **theapi)
- {
- struct winsync_plugin *elem = PR_LIST_HEAD(&winsync_plugin_list);
- while (elem && (elem != &winsync_plugin_list)) {
- if (theapi == elem->api) {
- return elem;
- }
- elem = PR_NEXT_LINK(elem);
- }
- return NULL;
- }
- /* returns 0 for success - 1 means already added - -1 means some error */
- static int
- windows_plugin_add(void **theapi, int maxapi)
- {
- int precedence = WINSYNC_PLUGIN_DEFAULT_PRECEDENCE;
- DECL_WINSYNC_API_IDX_FUNC(theapi,WINSYNC_PLUGIN_PRECEDENCE_CB,maxapi,winsync_plugin_precedence_cb,thefunc);
- if (thefunc) {
- /* supports precedence */
- precedence = (*thefunc)();
- }
- if (PR_CLIST_IS_EMPTY(&winsync_plugin_list)) {
- struct winsync_plugin *wpi = new_winsync_plugin(theapi, maxapi, precedence);
- PR_INSERT_LINK(wpi, &winsync_plugin_list);
- return 0;
- } else if (windows_plugin_find(theapi)) {
- return 1; /* already in list */
- } else {
- struct winsync_plugin *wpi = new_winsync_plugin(theapi, maxapi, precedence);
- struct winsync_plugin *elem = PR_LIST_HEAD(&winsync_plugin_list);
- while (elem && (elem != &winsync_plugin_list)) {
- if (precedence < elem->precedence) {
- PR_INSERT_BEFORE(wpi, elem);
- wpi = NULL; /* owned by list now */
- break;
- }
- elem = PR_NEXT_LINK(elem);
- }
- if (elem && wpi) { /* was not added - precedence too high */
- /* just add to end of list */
- PR_INSERT_BEFORE(wpi, elem);
- wpi = NULL; /* owned by list now */
- }
- /* if we got here and wpi is not NULL we need to free wpi */
- slapi_ch_free((void **)&wpi);
- return 0;
- }
- return -1;
- }
- static PRStatus
- windows_plugin_callonce(void)
- {
- char *guids[] = {WINSYNC_v3_0_GUID, WINSYNC_v2_0_GUID, WINSYNC_v1_0_GUID, NULL};
- int maxapis[] = {WINSYNC_PLUGIN_VERSION_3_END, WINSYNC_PLUGIN_VERSION_2_END,
- WINSYNC_PLUGIN_VERSION_1_END, 0};
- int ii;
- PR_INIT_CLIST(&winsync_plugin_list);
- /* loop through all of the registered winsync plugins - look for them in reverse
- version order (e.g. look for v3 first) - if there are no plugins registered
- for the given version, or we have already registered all plugins for a given
- version, just go to the next lowest version */
- for (ii = 0; guids[ii]; ++ii) {
- char *guid = guids[ii];
- int maxapi = maxapis[ii];
- void ***theapis = NULL;
-
- if (slapi_apib_get_interface_all(guid, &theapis) || (NULL == theapis)) {
- LDAPDebug1Arg(LDAP_DEBUG_PLUGIN,
- "<-- windows_plugin_callonce -- no more windows plugin APIs registered "
- "for GUID [%s] -- end\n",
- guid);
- } else {
- int idx;
- for (idx = 0; theapis && theapis[idx]; ++idx) {
- if (windows_plugin_add(theapis[idx], maxapi)) {
- LDAPDebug(LDAP_DEBUG_PLUGIN,
- "<-- windows_plugin_callonce -- already added windows plugin API "
- "[%d][0x%p] for GUID [%s] -- end\n",
- idx, theapis[idx], guid);
- }
- }
- }
- slapi_ch_free((void **)&theapis);
- }
- return PR_SUCCESS;
- }
- static struct winsync_plugin_cookie *
- new_winsync_plugin_cookie(void **theapi, void *cookie)
- {
- struct winsync_plugin_cookie *wpc = (struct winsync_plugin_cookie *)slapi_ch_calloc(1, sizeof(struct winsync_plugin_cookie));
- wpc->api = theapi;
- wpc->cookie = cookie;
- return wpc;
- }
- static void *
- winsync_plugin_cookie_find(const Repl_Agmt *ra, void **theapi)
- {
- if (ra) {
- struct winsync_plugin_cookie *list = (struct winsync_plugin_cookie *)windows_private_get_api_cookie(ra);
- if (list) {
- struct winsync_plugin_cookie *elem = PR_LIST_HEAD(list);
- while (elem && (elem != list)) {
- if (theapi == elem->api) {
- return elem->cookie;
- }
- elem = PR_NEXT_LINK(elem);
- }
- }
- }
- return NULL;
- }
- static void
- winsync_plugin_cookie_add(struct winsync_plugin_cookie **list, void **theapi, void *cookie)
- {
- struct winsync_plugin_cookie *elem = NULL;
- if (!*list) {
- *list = new_winsync_plugin_cookie(NULL, NULL);
- PR_INIT_CLIST(*list);
- }
- elem = new_winsync_plugin_cookie(theapi, cookie);
- PR_INSERT_BEFORE(elem, *list);
- return;
- }
- void
- windows_plugin_init(Repl_Agmt *ra)
- {
- struct winsync_plugin_cookie *list = NULL;
- void *cookie = NULL;
- LDAPDebug0Args( LDAP_DEBUG_PLUGIN, "--> windows_plugin_init_start -- begin\n");
- if (PR_CallOnce(&winsync_callOnce, windows_plugin_callonce)) {
- PRErrorCode prerr = PR_GetError();
- slapi_log_error(SLAPI_LOG_FATAL, "windows_plugin_init",
- "cannot initialize plugin: %d:%s\n", prerr,
- slapi_pr_strerror(prerr));
- return;
- }
- /* call each plugin init function in turn - store the returned cookie
- indexed by the api */
- {
- WINSYNC_PLUGIN_CALL_PLUGINS_BEGIN(WINSYNC_PLUGIN_INIT_CB,winsync_plugin_init_cb,thefunc)
- cookie = (*thefunc)(windows_private_get_directory_subtree(ra),
- windows_private_get_windows_subtree(ra));
- if (cookie) {
- winsync_plugin_cookie_add(&list, elem->api, cookie);
- }
- WINSYNC_PLUGIN_CALL_PLUGINS_END
- }
-
- windows_private_set_api_cookie(ra, list);
- LDAPDebug0Args( LDAP_DEBUG_PLUGIN, "<-- windows_plugin_init_start -- end\n");
- return;
- }
- void
- windows_plugin_cleanup_agmt(Repl_Agmt *ra)
- {
- struct winsync_plugin_cookie *list = (struct winsync_plugin_cookie *)windows_private_get_api_cookie(ra);
- struct winsync_plugin_cookie *elem = NULL;
- while (list && !PR_CLIST_IS_EMPTY(list)) {
- elem = PR_LIST_HEAD(list);
- PR_REMOVE_LINK(elem);
- slapi_ch_free((void **)&elem);
- }
- slapi_ch_free((void **)&list);
- windows_private_set_api_cookie(ra, NULL);
- return;
- }
- void
- winsync_plugin_call_dirsync_search_params_cb(const Repl_Agmt *ra, const char *agmt_dn,
- char **base, int *scope, char **filter,
- char ***attrs, LDAPControl ***serverctrls)
- {
- WINSYNC_PLUGIN_CALL_PLUGINS_COOKIE_BEGIN(WINSYNC_PLUGIN_DIRSYNC_SEARCH_CB,winsync_search_params_cb,thefunc)
- (*thefunc)(cookie, agmt_dn, base, scope, filter, attrs, serverctrls);
- WINSYNC_PLUGIN_CALL_PLUGINS_END;
- return;
- }
- void
- winsync_plugin_call_pre_ad_search_cb(const Repl_Agmt *ra, const char *agmt_dn,
- char **base, int *scope, char **filter,
- char ***attrs, LDAPControl ***serverctrls)
- {
- WINSYNC_PLUGIN_CALL_PLUGINS_COOKIE_BEGIN(WINSYNC_PLUGIN_PRE_AD_SEARCH_CB,winsync_search_params_cb,thefunc)
- (*thefunc)(cookie, agmt_dn, base, scope, filter, attrs, serverctrls);
- WINSYNC_PLUGIN_CALL_PLUGINS_END;
- return;
- }
- void
- winsync_plugin_call_pre_ds_search_entry_cb(const Repl_Agmt *ra, const char *agmt_dn,
- char **base, int *scope, char **filter,
- char ***attrs, LDAPControl ***serverctrls)
- {
- WINSYNC_PLUGIN_CALL_PLUGINS_COOKIE_BEGIN(WINSYNC_PLUGIN_PRE_DS_SEARCH_ENTRY_CB,winsync_search_params_cb,thefunc)
- (*thefunc)(cookie, agmt_dn, base, scope, filter, attrs, serverctrls);
- WINSYNC_PLUGIN_CALL_PLUGINS_END;
- return;
- }
- void
- winsync_plugin_call_pre_ds_search_all_cb(const Repl_Agmt *ra, const char *agmt_dn,
- char **base, int *scope, char **filter,
- char ***attrs, LDAPControl ***serverctrls)
- {
- WINSYNC_PLUGIN_CALL_PLUGINS_COOKIE_BEGIN(WINSYNC_PLUGIN_PRE_DS_SEARCH_ALL_CB,winsync_search_params_cb,thefunc)
- (*thefunc)(cookie, agmt_dn, base, scope, filter, attrs, serverctrls);
- WINSYNC_PLUGIN_CALL_PLUGINS_END;
- return;
- }
- void
- winsync_plugin_call_pre_ad_mod_user_cb(const Repl_Agmt *ra, const Slapi_Entry *rawentry,
- Slapi_Entry *ad_entry, Slapi_Entry *ds_entry,
- Slapi_Mods *smods, int *do_modify)
- {
- WINSYNC_PLUGIN_CALL_PLUGINS_COOKIE_BEGIN(WINSYNC_PLUGIN_PRE_AD_MOD_USER_CB,winsync_pre_mod_cb,thefunc)
- (*thefunc)(cookie, rawentry, ad_entry, ds_entry, smods, do_modify);
- WINSYNC_PLUGIN_CALL_PLUGINS_END;
- return;
- }
- void
- winsync_plugin_call_pre_ad_mod_group_cb(const Repl_Agmt *ra, const Slapi_Entry *rawentry,
- Slapi_Entry *ad_entry, Slapi_Entry *ds_entry,
- Slapi_Mods *smods, int *do_modify)
- {
- WINSYNC_PLUGIN_CALL_PLUGINS_COOKIE_BEGIN(WINSYNC_PLUGIN_PRE_AD_MOD_GROUP_CB,winsync_pre_mod_cb,thefunc)
- (*thefunc)(cookie, rawentry, ad_entry, ds_entry, smods, do_modify);
- WINSYNC_PLUGIN_CALL_PLUGINS_END;
- return;
- }
- void
- winsync_plugin_call_pre_ds_mod_user_cb(const Repl_Agmt *ra, const Slapi_Entry *rawentry,
- Slapi_Entry *ad_entry, Slapi_Entry *ds_entry,
- Slapi_Mods *smods, int *do_modify)
- {
- WINSYNC_PLUGIN_CALL_PLUGINS_COOKIE_BEGIN(WINSYNC_PLUGIN_PRE_DS_MOD_USER_CB,winsync_pre_mod_cb,thefunc)
- (*thefunc)(cookie, rawentry, ad_entry, ds_entry, smods, do_modify);
- WINSYNC_PLUGIN_CALL_PLUGINS_END;
- return;
- }
- void
- winsync_plugin_call_pre_ds_mod_group_cb(const Repl_Agmt *ra, const Slapi_Entry *rawentry,
- Slapi_Entry *ad_entry, Slapi_Entry *ds_entry,
- Slapi_Mods *smods, int *do_modify)
- {
- WINSYNC_PLUGIN_CALL_PLUGINS_COOKIE_BEGIN(WINSYNC_PLUGIN_PRE_DS_MOD_GROUP_CB,winsync_pre_mod_cb,thefunc)
- (*thefunc)(cookie, rawentry, ad_entry, ds_entry, smods, do_modify);
- WINSYNC_PLUGIN_CALL_PLUGINS_END;
- return;
- }
- void
- winsync_plugin_call_pre_ds_add_user_cb(const Repl_Agmt *ra, const Slapi_Entry *rawentry,
- Slapi_Entry *ad_entry, Slapi_Entry *ds_entry)
- {
- WINSYNC_PLUGIN_CALL_PLUGINS_COOKIE_BEGIN(WINSYNC_PLUGIN_PRE_DS_ADD_USER_CB,winsync_pre_add_cb,thefunc)
- (*thefunc)(cookie, rawentry, ad_entry, ds_entry);
- WINSYNC_PLUGIN_CALL_PLUGINS_END;
- return;
- }
- void
- winsync_plugin_call_pre_ds_add_group_cb(const Repl_Agmt *ra, const Slapi_Entry *rawentry,
- Slapi_Entry *ad_entry, Slapi_Entry *ds_entry)
- {
- WINSYNC_PLUGIN_CALL_PLUGINS_COOKIE_BEGIN(WINSYNC_PLUGIN_PRE_DS_ADD_GROUP_CB,winsync_pre_add_cb,thefunc)
- (*thefunc)(cookie, rawentry, ad_entry, ds_entry);
- WINSYNC_PLUGIN_CALL_PLUGINS_END;
- return;
- }
- void
- winsync_plugin_call_get_new_ds_user_dn_cb(const Repl_Agmt *ra, const Slapi_Entry *rawentry,
- Slapi_Entry *ad_entry, char **new_dn_string,
- const Slapi_DN *ds_suffix, const Slapi_DN *ad_suffix)
- {
- WINSYNC_PLUGIN_CALL_PLUGINS_COOKIE_BEGIN(WINSYNC_PLUGIN_GET_NEW_DS_USER_DN_CB,winsync_get_new_dn_cb,thefunc)
- (*thefunc)(cookie, rawentry, ad_entry, new_dn_string, ds_suffix, ad_suffix);
- WINSYNC_PLUGIN_CALL_PLUGINS_END;
- return;
- }
- void
- winsync_plugin_call_get_new_ds_group_dn_cb(const Repl_Agmt *ra, const Slapi_Entry *rawentry,
- Slapi_Entry *ad_entry, char **new_dn_string,
- const Slapi_DN *ds_suffix, const Slapi_DN *ad_suffix)
- {
- WINSYNC_PLUGIN_CALL_PLUGINS_COOKIE_BEGIN(WINSYNC_PLUGIN_GET_NEW_DS_GROUP_DN_CB,winsync_get_new_dn_cb,thefunc)
- (*thefunc)(cookie, rawentry, ad_entry, new_dn_string, ds_suffix, ad_suffix);
- WINSYNC_PLUGIN_CALL_PLUGINS_END;
- return;
- }
- void
- winsync_plugin_call_pre_ad_mod_user_mods_cb(const Repl_Agmt *ra, const Slapi_Entry *rawentry,
- const Slapi_DN *local_dn,
- const Slapi_Entry *ds_entry,
- LDAPMod * const *origmods,
- Slapi_DN *remote_dn, LDAPMod ***modstosend)
- {
- WINSYNC_PLUGIN_CALL_PLUGINS_COOKIE_BEGIN(WINSYNC_PLUGIN_PRE_AD_MOD_USER_MODS_CB,winsync_pre_ad_mod_mods_cb,thefunc)
- (*thefunc)(cookie, rawentry, local_dn, ds_entry, origmods, remote_dn, modstosend);
- WINSYNC_PLUGIN_CALL_PLUGINS_END;
- return;
- }
- void
- winsync_plugin_call_pre_ad_mod_group_mods_cb(const Repl_Agmt *ra, const Slapi_Entry *rawentry,
- const Slapi_DN *local_dn,
- const Slapi_Entry *ds_entry,
- LDAPMod * const *origmods,
- Slapi_DN *remote_dn, LDAPMod ***modstosend)
- {
- WINSYNC_PLUGIN_CALL_PLUGINS_COOKIE_BEGIN(WINSYNC_PLUGIN_PRE_AD_MOD_GROUP_MODS_CB,winsync_pre_ad_mod_mods_cb,thefunc)
- (*thefunc)(cookie, rawentry, local_dn, ds_entry, origmods, remote_dn, modstosend);
- WINSYNC_PLUGIN_CALL_PLUGINS_END;
- return;
- }
- int
- winsync_plugin_call_can_add_entry_to_ad_cb(const Repl_Agmt *ra, const Slapi_Entry *local_entry,
- const Slapi_DN *remote_dn)
- {
- int canadd = 1;
- WINSYNC_PLUGIN_CALL_PLUGINS_COOKIE_BEGIN(WINSYNC_PLUGIN_CAN_ADD_ENTRY_TO_AD_CB,winsync_can_add_to_ad_cb,thefunc)
- if (canadd) {
- canadd = (*thefunc)(cookie, local_entry, remote_dn);
- }
- WINSYNC_PLUGIN_CALL_PLUGINS_END;
- return canadd;
- }
- void
- winsync_plugin_call_begin_update_cb(const Repl_Agmt *ra, const Slapi_DN *ds_subtree,
- const Slapi_DN *ad_subtree, int is_total)
- {
- WINSYNC_PLUGIN_CALL_PLUGINS_COOKIE_BEGIN(WINSYNC_PLUGIN_BEGIN_UPDATE_CB,winsync_plugin_update_cb,thefunc)
- (*thefunc)(cookie, ds_subtree, ad_subtree, is_total);
- WINSYNC_PLUGIN_CALL_PLUGINS_END;
- return;
- }
- void
- winsync_plugin_call_end_update_cb(const Repl_Agmt *ra, const Slapi_DN *ds_subtree,
- const Slapi_DN *ad_subtree, int is_total)
- {
- WINSYNC_PLUGIN_CALL_PLUGINS_COOKIE_BEGIN(WINSYNC_PLUGIN_END_UPDATE_CB,winsync_plugin_update_cb,thefunc)
- (*thefunc)(cookie, ds_subtree, ad_subtree, is_total);
- WINSYNC_PLUGIN_CALL_PLUGINS_END;
- return;
- }
- void
- winsync_plugin_call_destroy_agmt_cb(const Repl_Agmt *ra,
- const Slapi_DN *ds_subtree,
- const Slapi_DN *ad_subtree)
- {
- WINSYNC_PLUGIN_CALL_PLUGINS_COOKIE_BEGIN(WINSYNC_PLUGIN_DESTROY_AGMT_CB,winsync_plugin_destroy_agmt_cb,thefunc)
- (*thefunc)(cookie, ds_subtree, ad_subtree);
- WINSYNC_PLUGIN_CALL_PLUGINS_END;
- return;
- }
- void
- winsync_plugin_call_post_ad_mod_user_cb(const Repl_Agmt *ra, const Slapi_Entry *rawentry,
- Slapi_Entry *ad_entry, Slapi_Entry *ds_entry,
- Slapi_Mods *smods, int *result)
- {
- WINSYNC_PLUGIN_CALL_PLUGINS_COOKIE_BEGIN(WINSYNC_PLUGIN_POST_AD_MOD_USER_CB,winsync_post_mod_cb,thefunc)
- (*thefunc)(cookie, rawentry, ad_entry, ds_entry, smods, result);
- WINSYNC_PLUGIN_CALL_PLUGINS_END;
- return;
- }
- void
- winsync_plugin_call_post_ad_mod_group_cb(const Repl_Agmt *ra, const Slapi_Entry *rawentry,
- Slapi_Entry *ad_entry, Slapi_Entry *ds_entry,
- Slapi_Mods *smods, int *result)
- {
- WINSYNC_PLUGIN_CALL_PLUGINS_COOKIE_BEGIN(WINSYNC_PLUGIN_POST_AD_MOD_GROUP_CB,winsync_post_mod_cb,thefunc)
- (*thefunc)(cookie, rawentry, ad_entry, ds_entry, smods, result);
- WINSYNC_PLUGIN_CALL_PLUGINS_END;
- return;
- }
- void
- winsync_plugin_call_post_ds_mod_user_cb(const Repl_Agmt *ra, const Slapi_Entry *rawentry,
- Slapi_Entry *ad_entry, Slapi_Entry *ds_entry,
- Slapi_Mods *smods, int *result)
- {
- WINSYNC_PLUGIN_CALL_PLUGINS_COOKIE_BEGIN(WINSYNC_PLUGIN_POST_DS_MOD_USER_CB,winsync_post_mod_cb,thefunc)
- (*thefunc)(cookie, rawentry, ad_entry, ds_entry, smods, result);
- WINSYNC_PLUGIN_CALL_PLUGINS_END;
- return;
- }
- void
- winsync_plugin_call_post_ds_mod_group_cb(const Repl_Agmt *ra, const Slapi_Entry *rawentry,
- Slapi_Entry *ad_entry, Slapi_Entry *ds_entry,
- Slapi_Mods *smods, int *result)
- {
- WINSYNC_PLUGIN_CALL_PLUGINS_COOKIE_BEGIN(WINSYNC_PLUGIN_POST_DS_MOD_GROUP_CB,winsync_post_mod_cb,thefunc)
- (*thefunc)(cookie, rawentry, ad_entry, ds_entry, smods, result);
- WINSYNC_PLUGIN_CALL_PLUGINS_END;
- return;
- }
- void
- winsync_plugin_call_post_ds_add_user_cb(const Repl_Agmt *ra, const Slapi_Entry *rawentry,
- Slapi_Entry *ad_entry, Slapi_Entry *ds_entry, int *result)
- {
- WINSYNC_PLUGIN_CALL_PLUGINS_COOKIE_BEGIN(WINSYNC_PLUGIN_POST_DS_ADD_USER_CB,winsync_post_add_cb,thefunc)
- (*thefunc)(cookie, rawentry, ad_entry, ds_entry, result);
- WINSYNC_PLUGIN_CALL_PLUGINS_END;
- return;
- }
- void
- winsync_plugin_call_post_ds_add_group_cb(const Repl_Agmt *ra, const Slapi_Entry *rawentry,
- Slapi_Entry *ad_entry, Slapi_Entry *ds_entry, int *result)
- {
- WINSYNC_PLUGIN_CALL_PLUGINS_COOKIE_BEGIN(WINSYNC_PLUGIN_POST_DS_ADD_GROUP_CB,winsync_post_add_cb,thefunc)
- (*thefunc)(cookie, rawentry, ad_entry, ds_entry, result);
- WINSYNC_PLUGIN_CALL_PLUGINS_END;
- return;
- }
- void
- winsync_plugin_call_pre_ad_add_user_cb(const Repl_Agmt *ra, Slapi_Entry *ad_entry,
- Slapi_Entry *ds_entry)
- {
- WINSYNC_PLUGIN_CALL_PLUGINS_COOKIE_BEGIN(WINSYNC_PLUGIN_PRE_AD_ADD_USER_CB,winsync_pre_ad_add_cb,thefunc)
- (*thefunc)(cookie, ad_entry, ds_entry);
- WINSYNC_PLUGIN_CALL_PLUGINS_END;
- return;
- }
- void
- winsync_plugin_call_pre_ad_add_group_cb(const Repl_Agmt *ra, Slapi_Entry *ad_entry,
- Slapi_Entry *ds_entry)
- {
- WINSYNC_PLUGIN_CALL_PLUGINS_COOKIE_BEGIN(WINSYNC_PLUGIN_PRE_AD_ADD_GROUP_CB,winsync_pre_ad_add_cb,thefunc)
- (*thefunc)(cookie, ad_entry, ds_entry);
- WINSYNC_PLUGIN_CALL_PLUGINS_END;
- return;
- }
- void
- winsync_plugin_call_post_ad_add_user_cb(const Repl_Agmt *ra, Slapi_Entry *ad_entry,
- Slapi_Entry *ds_entry, int *result)
- {
- WINSYNC_PLUGIN_CALL_PLUGINS_COOKIE_BEGIN(WINSYNC_PLUGIN_POST_AD_ADD_USER_CB,winsync_post_ad_add_cb,thefunc)
- (*thefunc)(cookie, ad_entry, ds_entry, result);
- WINSYNC_PLUGIN_CALL_PLUGINS_END;
- return;
- }
- void
- winsync_plugin_call_post_ad_add_group_cb(const Repl_Agmt *ra, Slapi_Entry *ad_entry,
- Slapi_Entry *ds_entry, int *result)
- {
- WINSYNC_PLUGIN_CALL_PLUGINS_COOKIE_BEGIN(WINSYNC_PLUGIN_POST_AD_ADD_GROUP_CB,winsync_post_ad_add_cb,thefunc)
- (*thefunc)(cookie, ad_entry, ds_entry, result);
- WINSYNC_PLUGIN_CALL_PLUGINS_END;
- return;
- }
- void
- winsync_plugin_call_post_ad_mod_user_mods_cb(const Repl_Agmt *ra, const Slapi_Entry *rawentry,
- const Slapi_DN *local_dn,
- const Slapi_Entry *ds_entry,
- LDAPMod * const *origmods,
- Slapi_DN *remote_dn, LDAPMod **modstosend, int *result)
- {
- WINSYNC_PLUGIN_CALL_PLUGINS_COOKIE_BEGIN(WINSYNC_PLUGIN_POST_AD_MOD_USER_MODS_CB,winsync_post_ad_mod_mods_cb,thefunc)
- (*thefunc)(cookie, rawentry, local_dn, ds_entry, origmods, remote_dn, modstosend, result);
- WINSYNC_PLUGIN_CALL_PLUGINS_END;
- return;
- }
- void
- winsync_plugin_call_post_ad_mod_group_mods_cb(const Repl_Agmt *ra, const Slapi_Entry *rawentry,
- const Slapi_DN *local_dn,
- const Slapi_Entry *ds_entry,
- LDAPMod * const *origmods,
- Slapi_DN *remote_dn, LDAPMod **modstosend, int *result)
- {
- WINSYNC_PLUGIN_CALL_PLUGINS_COOKIE_BEGIN(WINSYNC_PLUGIN_POST_AD_MOD_GROUP_MODS_CB,winsync_post_ad_mod_mods_cb,thefunc)
- (*thefunc)(cookie, rawentry, local_dn, ds_entry, origmods, remote_dn, modstosend, result);
- WINSYNC_PLUGIN_CALL_PLUGINS_END;
- return;
- }
- /*
- The following are sample code stubs to show how to implement
- a plugin which uses this api
- */
- #define WINSYNC_SAMPLE_CODE
- #ifdef WINSYNC_SAMPLE_CODE
- #include "slapi-plugin.h"
- #include "winsync-plugin.h"
- static char *test_winsync_plugin_name = "test_winsync_api";
- static void *
- test_winsync_api_init(const Slapi_DN *ds_subtree, const Slapi_DN *ad_subtree)
- {
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "--> test_winsync_init [%s] [%s] -- begin\n",
- slapi_sdn_get_dn(ds_subtree),
- slapi_sdn_get_dn(ad_subtree));
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "<-- test_winsync_init -- end\n");
- return NULL;
- }
- static void
- test_winsync_dirsync_search_params_cb(void *cbdata, const char *agmt_dn,
- char **base, int *scope, char **filter,
- char ***attrs, LDAPControl ***serverctrls)
- {
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "--> test_winsync_dirsync_search_params_cb -- begin\n");
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "<-- test_winsync_dirsync_search_params_cb -- end\n");
- return;
- }
- /* called before searching for a single entry from AD - agmt_dn will be NULL */
- static void
- test_winsync_pre_ad_search_cb(void *cbdata, const char *agmt_dn,
- char **base, int *scope, char **filter,
- char ***attrs, LDAPControl ***serverctrls)
- {
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "--> test_winsync_pre_ad_search_cb -- begin\n");
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "<-- test_winsync_pre_ad_search_cb -- end\n");
- return;
- }
- /* called before an internal search to get a single DS entry - agmt_dn will be NULL */
- static void
- test_winsync_pre_ds_search_entry_cb(void *cbdata, const char *agmt_dn,
- char **base, int *scope, char **filter,
- char ***attrs, LDAPControl ***serverctrls)
- {
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "--> test_winsync_pre_ds_search_cb -- begin\n");
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "<-- test_winsync_pre_ds_search_cb -- end\n");
- return;
- }
- /* called before the total update to get all entries from the DS to sync to AD */
- static void
- test_winsync_pre_ds_search_all_cb(void *cbdata, const char *agmt_dn,
- char **base, int *scope, char **filter,
- char ***attrs, LDAPControl ***serverctrls)
- {
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "--> test_winsync_pre_ds_search_all_cb -- orig filter [%s] -- begin\n",
- ((filter && *filter) ? *filter : "NULL"));
- #ifdef THIS_IS_JUST_AN_EXAMPLE
- if (filter) {
- /* We only want to grab users from the ds side - no groups */
- slapi_ch_free_string(filter);
- /* maybe use ntUniqueId=* - only get users that have already been
- synced with AD already - ntUniqueId and ntUserDomainId are
- indexed for equality only - need to add presence? */
- *filter = slapi_ch_strdup("(&(objectclass=ntuser)(ntUserDomainId=*))");
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "--> test_winsync_pre_ds_search_all_cb -- new filter [%s]\n",
- *filter ? *filter : "NULL"));
- }
- #endif
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "<-- test_winsync_pre_ds_search_all_cb -- end\n");
- return;
- }
- static void
- test_winsync_pre_ad_mod_user_cb(void *cbdata, const Slapi_Entry *rawentry,
- Slapi_Entry *ad_entry, Slapi_Entry *ds_entry,
- Slapi_Mods *smods, int *do_modify)
- {
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "--> test_winsync_pre_ad_mod_user_cb -- begin\n");
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "<-- test_winsync_pre_ad_mod_user_cb -- end\n");
- return;
- }
- static void
- test_winsync_pre_ad_mod_group_cb(void *cbdata, const Slapi_Entry *rawentry,
- Slapi_Entry *ad_entry, Slapi_Entry *ds_entry,
- Slapi_Mods *smods, int *do_modify)
- {
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "--> test_winsync_pre_ad_mod_group_cb -- begin\n");
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "<-- test_winsync_pre_ad_mod_group_cb -- end\n");
- return;
- }
- static void
- test_winsync_pre_ds_mod_user_cb(void *cbdata, const Slapi_Entry *rawentry,
- Slapi_Entry *ad_entry, Slapi_Entry *ds_entry,
- Slapi_Mods *smods, int *do_modify)
- {
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "--> test_winsync_pre_ds_mod_user_cb -- begin\n");
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "<-- test_winsync_pre_ds_mod_user_cb -- end\n");
- return;
- }
- static void
- test_winsync_pre_ds_mod_group_cb(void *cbdata, const Slapi_Entry *rawentry,
- Slapi_Entry *ad_entry, Slapi_Entry *ds_entry,
- Slapi_Mods *smods, int *do_modify)
- {
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "--> test_winsync_pre_ds_mod_group_cb -- begin\n");
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "<-- test_winsync_pre_ds_mod_group_cb -- end\n");
- return;
- }
- static void
- test_winsync_pre_ds_add_user_cb(void *cbdata, const Slapi_Entry *rawentry,
- Slapi_Entry *ad_entry, Slapi_Entry *ds_entry)
- {
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "--> test_winsync_pre_ds_add_user_cb -- begin\n");
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "<-- test_winsync_pre_ds_add_user_cb -- end\n");
- return;
- }
- static void
- test_winsync_pre_ds_add_group_cb(void *cbdata, const Slapi_Entry *rawentry,
- Slapi_Entry *ad_entry, Slapi_Entry *ds_entry)
- {
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "--> test_winsync_pre_ds_add_group_cb -- begin\n");
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "<-- test_winsync_pre_ds_add_group_cb -- end\n");
- return;
- }
- static void
- test_winsync_get_new_ds_user_dn_cb(void *cbdata, const Slapi_Entry *rawentry,
- Slapi_Entry *ad_entry, char **new_dn_string,
- const Slapi_DN *ds_suffix, const Slapi_DN *ad_suffix)
- {
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "--> test_winsync_get_new_ds_user_dn_cb -- old dn [%s] -- begin\n",
- *new_dn_string);
- #ifdef THIS_IS_JUST_AN_EXAMPLE
- char **rdns = slapi_ldap_explode_dn(*new_dn_string, 0);
- if (!rdns || !rdns[0]) {
- slapi_ldap_value_free(rdns);
- return;
- }
- slapi_ch_free_string(new_dn_string);
- *new_dn_string = PR_smprintf("%s,%s", rdns[0], slapi_sdn_get_dn(ds_suffix));
- slapi_ldap_value_free(rdns);
- #endif
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "<-- test_winsync_get_new_ds_user_dn_cb -- new dn [%s] -- end\n",
- *new_dn_string);
- return;
- }
- static void
- test_winsync_get_new_ds_group_dn_cb(void *cbdata, const Slapi_Entry *rawentry,
- Slapi_Entry *ad_entry, char **new_dn_string,
- const Slapi_DN *ds_suffix, const Slapi_DN *ad_suffix)
- {
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "--> test_winsync_get_new_ds_group_dn_cb -- begin\n");
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "<-- test_winsync_get_new_ds_group_dn_cb -- end\n");
- return;
- }
- static void
- test_winsync_pre_ad_mod_user_mods_cb(void *cbdata, const Slapi_Entry *rawentry,
- const Slapi_Entry *ds_entry,
- const Slapi_DN *local_dn, LDAPMod * const *origmods,
- Slapi_DN *remote_dn, LDAPMod ***modstosend)
- {
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "--> test_winsync_pre_ad_mod_user_mods_cb -- begin\n");
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "<-- test_winsync_pre_ad_mod_user_mods_cb -- end\n");
- return;
- }
- static void
- test_winsync_pre_ad_mod_group_mods_cb(void *cbdata, const Slapi_Entry *rawentry,
- const Slapi_Entry *ds_entry,
- const Slapi_DN *local_dn, LDAPMod * const *origmods,
- Slapi_DN *remote_dn, LDAPMod ***modstosend)
- {
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "--> test_winsync_pre_ad_mod_group_mods_cb -- begin\n");
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "<-- test_winsync_pre_ad_mod_group_mods_cb -- end\n");
- return;
- }
- static int
- test_winsync_can_add_entry_to_ad_cb(void *cbdata, const Slapi_Entry *local_entry,
- const Slapi_DN *remote_dn)
- {
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "--> test_winsync_can_add_entry_to_ad_cb -- begin\n");
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "<-- test_winsync_can_add_entry_to_ad_cb -- end\n");
- /* return 0;*/ /* false - do not allow entries to be added to ad */
- return 1; /* true - allow entries to be added to ad */
- }
- static void
- test_winsync_begin_update_cb(void *cbdata, const Slapi_DN *ds_subtree,
- const Slapi_DN *ad_subtree, int is_total)
- {
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "--> test_winsync_begin_update_cb -- begin\n");
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "<-- test_winsync_begin_update_cb -- end\n");
- return;
- }
- static void
- test_winsync_end_update_cb(void *cbdata, const Slapi_DN *ds_subtree,
- const Slapi_DN *ad_subtree, int is_total)
- {
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "--> test_winsync_end_update_cb -- begin\n");
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "<-- test_winsync_end_update_cb -- end\n");
- return;
- }
- static void
- test_winsync_destroy_agmt_cb(void *cbdata, const Slapi_DN *ds_subtree,
- const Slapi_DN *ad_subtree)
- {
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "--> test_winsync_destroy_agmt_cb -- begin\n");
- /* free(cbdata); */
-
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "<-- test_winsync_destroy_agmt_cb -- end\n");
- return;
- }
- static void
- test_winsync_post_ad_mod_user_cb(void *cookie, const Slapi_Entry *rawentry, Slapi_Entry *ad_entry, Slapi_Entry *ds_entry, Slapi_Mods *smods, int *result)
- {
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "--> test_winsync_post_ad_mod_user_cb -- begin\n");
- #ifdef THIS_IS_JUST_AN_EXAMPLE
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "Result of modifying AD entry [%s] was [%d:%s]\n",
- slapi_entry_get_dn(ad_entry), *result, ldap_err2string(*result));
- #endif
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "<-- test_winsync_post_ad_mod_user_cb -- end\n");
- return;
- }
- static void
- test_winsync_post_ad_mod_group_cb(void *cookie, const Slapi_Entry *rawentry, Slapi_Entry *ad_entry, Slapi_Entry *ds_entry, Slapi_Mods *smods, int *result)
- {
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "--> test_winsync_post_ad_mod_group_cb -- begin\n");
- #ifdef THIS_IS_JUST_AN_EXAMPLE
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "Result of modifying AD entry [%s] was [%d:%s]\n",
- slapi_entry_get_dn(ad_entry), *result, ldap_err2string(*result));
- #endif
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "<-- test_winsync_post_ad_mod_group_cb -- end\n");
- return;
- }
- static void
- test_winsync_post_ds_mod_user_cb(void *cookie, const Slapi_Entry *rawentry, Slapi_Entry *ad_entry, Slapi_Entry *ds_entry, Slapi_Mods *smods, int *result)
- {
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "--> test_winsync_post_ds_mod_user_cb -- begin\n");
- #ifdef THIS_IS_JUST_AN_EXAMPLE
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "Result of modifying DS entry [%s] was [%d:%s]\n",
- slapi_entry_get_dn(ds_entry), *result, ldap_err2string(*result));
- #endif
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "<-- test_winsync_post_ds_mod_user_cb -- end\n");
- return;
- }
- static void
- test_winsync_post_ds_mod_group_cb(void *cookie, const Slapi_Entry *rawentry, Slapi_Entry *ad_entry, Slapi_Entry *ds_entry, Slapi_Mods *smods, int *result)
- {
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "--> test_winsync_post_ds_mod_group_cb -- begin\n");
- #ifdef THIS_IS_JUST_AN_EXAMPLE
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "Result of modifying DS entry [%s] was [%d:%s]\n",
- slapi_entry_get_dn(ds_entry), *result, ldap_err2string(*result));
- #endif
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "<-- test_winsync_post_ds_mod_group_cb -- end\n");
- return;
- }
- static void
- test_winsync_post_ds_add_user_cb(void *cookie, const Slapi_Entry *rawentry, Slapi_Entry *ad_entry, Slapi_Entry *ds_entry, int *result)
- {
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "--> test_winsync_post_ds_add_user_cb -- begin\n");
- #ifdef THIS_IS_JUST_AN_EXAMPLE
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "Result of adding DS entry [%s] was [%d:%s]\n",
- slapi_entry_get_dn(ds_entry), *result, ldap_err2string(*result));
- #endif
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "<-- test_winsync_post_ds_add_user_cb -- end\n");
- return;
- }
- static void
- test_winsync_post_ds_add_group_cb(void *cookie, const Slapi_Entry *rawentry, Slapi_Entry *ad_entry, Slapi_Entry *ds_entry, int *result)
- {
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "--> test_winsync_post_ds_add_group_cb -- begin\n");
- #ifdef THIS_IS_JUST_AN_EXAMPLE
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "Result of adding DS entry [%s] was [%d:%s]\n",
- slapi_entry_get_dn(ds_entry), *result, ldap_err2string(*result));
- #endif
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "<-- test_winsync_post_ds_add_group_cb -- end\n");
- return;
- }
- static void
- test_winsync_pre_ad_add_user_cb(void *cookie, Slapi_Entry *ds_entry, Slapi_Entry *ad_entry)
- {
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "--> test_winsync_pre_ad_add_user_cb -- begin\n");
- #ifdef THIS_IS_JUST_AN_EXAMPLE
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "Adding AD entry [%s] from add of DS entry [%s]\n",
- slapi_entry_get_dn(ad_entry), slapi_entry_get_dn(ds_entry));
- /* make modifications to ad_entry here */
- #endif
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "<-- test_winsync_pre_ad_add_user_cb -- end\n");
- return;
- }
- static void
- test_winsync_pre_ad_add_group_cb(void *cookie, Slapi_Entry *ds_entry, Slapi_Entry *ad_entry)
- {
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "--> test_winsync_pre_ad_add_group_cb -- begin\n");
- #ifdef THIS_IS_JUST_AN_EXAMPLE
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "Adding AD entry [%s] from add of DS entry [%s]\n",
- slapi_entry_get_dn(ad_entry), slapi_entry_get_dn(ds_entry));
- /* make modifications to ad_entry here */
- #endif
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "<-- test_winsync_pre_ad_add_group_cb -- end\n");
- return;
- }
- static void
- test_winsync_post_ad_add_user_cb(void *cookie, Slapi_Entry *ds_entry, Slapi_Entry *ad_entry, int *result)
- {
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "--> test_winsync_post_ad_add_user_cb -- begin\n");
- #ifdef THIS_IS_JUST_AN_EXAMPLE
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "Result of adding AD entry [%s] was [%d:%s]\n",
- slapi_entry_get_dn(ad_entry), *result, ldap_err2string(*result));
- #endif
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "<-- test_winsync_post_ad_add_user_cb -- end\n");
- return;
- }
- static void
- test_winsync_post_ad_add_group_cb(void *cookie, Slapi_Entry *ds_entry, Slapi_Entry *ad_entry, int *result)
- {
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "--> test_winsync_post_ad_add_group_cb -- begin\n");
- #ifdef THIS_IS_JUST_AN_EXAMPLE
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "Result of adding AD entry [%s] was [%d:%s]\n",
- slapi_entry_get_dn(ad_entry), *result, ldap_err2string(*result));
- #endif
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "<-- test_winsync_post_ad_add_group_cb -- end\n");
- return;
- }
- static void
- test_winsync_post_ad_mod_user_mods_cb(void *cookie, const Slapi_Entry *rawentry, const Slapi_DN *local_dn, const Slapi_Entry *ds_entry, LDAPMod * const *origmods, Slapi_DN *remote_dn, LDAPMod ***modstosend, int *result)
- {
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "--> test_winsync_post_ad_mod_user_mods_cb -- begin\n");
- #ifdef THIS_IS_JUST_AN_EXAMPLE
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "Result of modifying AD entry [%s] was [%d:%s]\n",
- slapi_sdn_get_dn(remote_dn), *result, ldap_err2string(*result));
- #endif
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "<-- test_winsync_post_ad_mod_user_mods_cb -- end\n");
- return;
- }
- static void
- test_winsync_post_ad_mod_group_mods_cb(void *cookie, const Slapi_Entry *rawentry, const Slapi_DN *local_dn, const Slapi_Entry *ds_entry, LDAPMod * const *origmods, Slapi_DN *remote_dn, LDAPMod ***modstosend, int *result)
- {
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "--> test_winsync_post_ad_mod_group_mods_cb -- begin\n");
- #ifdef THIS_IS_JUST_AN_EXAMPLE
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "Result of modifying AD entry [%s] was [%d:%s]\n",
- slapi_sdn_get_dn(remote_dn), *result, ldap_err2string(*result));
- #endif
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "<-- test_winsync_post_ad_mod_group_mods_cb -- end\n");
- return;
- }
- static int
- test_winsync_precedence(void)
- {
- return 99;
- }
- /**
- * Plugin identifiers
- */
- static Slapi_PluginDesc test_winsync_pdesc = {
- "test-winsync-plugin",
- VENDOR,
- DS_PACKAGE_VERSION,
- "test winsync plugin"
- };
- static Slapi_ComponentId *test_winsync_plugin_id = NULL;
- #ifdef TEST_V1_WINSYNC_API
- static void *test_winsync_api_v1[] = {
- NULL, /* reserved for api broker use, must be zero */
- test_winsync_api_init,
- test_winsync_dirsync_search_params_cb,
- test_winsync_pre_ad_search_cb,
- test_winsync_pre_ds_search_entry_cb,
- test_winsync_pre_ds_search_all_cb,
- test_winsync_pre_ad_mod_user_cb,
- test_winsync_pre_ad_mod_group_cb,
- test_winsync_pre_ds_mod_user_cb,
- test_winsync_pre_ds_mod_group_cb,
- test_winsync_pre_ds_add_user_cb,
- test_winsync_pre_ds_add_group_cb,
- test_winsync_get_new_ds_user_dn_cb,
- test_winsync_get_new_ds_group_dn_cb,
- test_winsync_pre_ad_mod_user_mods_cb,
- test_winsync_pre_ad_mod_group_mods_cb,
- test_winsync_can_add_entry_to_ad_cb,
- test_winsync_begin_update_cb,
- test_winsync_end_update_cb,
- test_winsync_destroy_agmt_cb
- };
- #endif /* TEST_V1_WINSYNC_API */
- #ifdef TEST_V2_WINSYNC_API
- static void *test_winsync_api_v2[] = {
- NULL, /* reserved for api broker use, must be zero */
- test_winsync_api_init,
- test_winsync_dirsync_search_params_cb,
- test_winsync_pre_ad_search_cb,
- test_winsync_pre_ds_search_entry_cb,
- test_winsync_pre_ds_search_all_cb,
- test_winsync_pre_ad_mod_user_cb,
- test_winsync_pre_ad_mod_group_cb,
- test_winsync_pre_ds_mod_user_cb,
- test_winsync_pre_ds_mod_group_cb,
- test_winsync_pre_ds_add_user_cb,
- test_winsync_pre_ds_add_group_cb,
- test_winsync_get_new_ds_user_dn_cb,
- test_winsync_get_new_ds_group_dn_cb,
- test_winsync_pre_ad_mod_user_mods_cb,
- test_winsync_pre_ad_mod_group_mods_cb,
- test_winsync_can_add_entry_to_ad_cb,
- test_winsync_begin_update_cb,
- test_winsync_end_update_cb,
- test_winsync_destroy_agmt_cb,
- test_winsync_post_ad_mod_user_cb,
- test_winsync_post_ad_mod_group_cb,
- test_winsync_post_ds_mod_user_cb,
- test_winsync_post_ds_mod_group_cb,
- test_winsync_post_ds_add_user_cb,
- test_winsync_post_ds_add_group_cb,
- test_winsync_pre_ad_add_user_cb,
- test_winsync_pre_ad_add_group_cb,
- test_winsync_post_ad_add_user_cb,
- test_winsync_post_ad_add_group_cb,
- test_winsync_post_ad_mod_user_mods_cb,
- test_winsync_post_ad_mod_group_mods_cb
- };
- #endif /* TEST_V2_WINSYNC_API */
- static void *test_winsync_api_v3[] = {
- NULL, /* reserved for api broker use, must be zero */
- test_winsync_api_init,
- test_winsync_dirsync_search_params_cb,
- test_winsync_pre_ad_search_cb,
- test_winsync_pre_ds_search_entry_cb,
- test_winsync_pre_ds_search_all_cb,
- test_winsync_pre_ad_mod_user_cb,
- test_winsync_pre_ad_mod_group_cb,
- test_winsync_pre_ds_mod_user_cb,
- test_winsync_pre_ds_mod_group_cb,
- test_winsync_pre_ds_add_user_cb,
- test_winsync_pre_ds_add_group_cb,
- test_winsync_get_new_ds_user_dn_cb,
- test_winsync_get_new_ds_group_dn_cb,
- test_winsync_pre_ad_mod_user_mods_cb,
- test_winsync_pre_ad_mod_group_mods_cb,
- test_winsync_can_add_entry_to_ad_cb,
- test_winsync_begin_update_cb,
- test_winsync_end_update_cb,
- test_winsync_destroy_agmt_cb,
- test_winsync_post_ad_mod_user_cb,
- test_winsync_post_ad_mod_group_cb,
- test_winsync_post_ds_mod_user_cb,
- test_winsync_post_ds_mod_group_cb,
- test_winsync_post_ds_add_user_cb,
- test_winsync_post_ds_add_group_cb,
- test_winsync_pre_ad_add_user_cb,
- test_winsync_pre_ad_add_group_cb,
- test_winsync_post_ad_add_user_cb,
- test_winsync_post_ad_add_group_cb,
- test_winsync_post_ad_mod_user_mods_cb,
- test_winsync_post_ad_mod_group_mods_cb,
- test_winsync_precedence
- };
- static int
- test_winsync_plugin_start(Slapi_PBlock *pb)
- {
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "--> test_winsync_plugin_start -- begin\n");
- if( slapi_apib_register(WINSYNC_v3_0_GUID, test_winsync_api_v3) ) {
- slapi_log_error( SLAPI_LOG_FATAL, test_winsync_plugin_name,
- "<-- test_winsync_plugin_start -- failed to register winsync api -- end\n");
- return -1;
- }
-
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "<-- test_winsync_plugin_start -- end\n");
- return 0;
- }
- static int
- test_winsync_plugin_close(Slapi_PBlock *pb)
- {
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "--> test_winsync_plugin_close -- begin\n");
- slapi_apib_unregister(WINSYNC_v3_0_GUID);
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "<-- test_winsync_plugin_close -- end\n");
- return 0;
- }
- /* this is the slapi plugin init function,
- not the one used by the winsync api
- */
- int test_winsync_plugin_init(Slapi_PBlock *pb)
- {
- slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "--> test_winsync_plugin_init -- begin\n");
- if ( slapi_pblock_set( pb, SLAPI_PLUGIN_VERSION,
- SLAPI_PLUGIN_VERSION_01 ) != 0 ||
- slapi_pblock_set(pb, SLAPI_PLUGIN_START_FN,
- (void *) test_winsync_plugin_start ) != 0 ||
- slapi_pblock_set(pb, SLAPI_PLUGIN_CLOSE_FN,
- (void *) test_winsync_plugin_close ) != 0 ||
- slapi_pblock_set( pb, SLAPI_PLUGIN_DESCRIPTION,
- (void *)&test_winsync_pdesc ) != 0 )
- {
- slapi_log_error( SLAPI_LOG_FATAL, test_winsync_plugin_name,
- "<-- test_winsync_plugin_init -- failed to register plugin -- end\n");
- return -1;
- }
- /* Retrieve and save the plugin identity to later pass to
- internal operations */
- if (slapi_pblock_get(pb, SLAPI_PLUGIN_IDENTITY, &test_winsync_plugin_id) != 0) {
- slapi_log_error(SLAPI_LOG_FATAL, test_winsync_plugin_name,
- "<-- test_winsync_plugin_init -- failed to retrieve plugin identity -- end\n");
- return -1;
- }
- slapi_log_error( SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
- "<-- test_winsync_plugin_init -- end\n");
- return 0;
- }
- /*
- dn: cn=Test Winsync API,cn=plugins,cn=config
- objectclass: top
- objectclass: nsSlapdPlugin
- objectclass: extensibleObject
- cn: Test Winsync API
- nsslapd-pluginpath: libtestwinsync-plugin
- nsslapd-plugininitfunc: test_winsync_plugin_init
- nsslapd-plugintype: preoperation
- nsslapd-pluginenabled: on
- nsslapd-plugin-depends-on-type: database
- nsslapd-pluginDescription: Test Winsync
- nsslapd-pluginVendor: 389 project
- nsslapd-pluginId: test-winsync
- nsslapd-pluginVersion: 0.9
- */
- #endif /* WINSYNC_SAMPLE_CODE */
- /* #define WINSYNC_TEST_IPA */
- #ifdef WINSYNC_TEST_IPA
- #include "ipa-winsync.c"
- #include "ipa-winsync-config.c"
- #endif
|