winsync-plugin.h 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602
  1. /** BEGIN COPYRIGHT BLOCK
  2. * This Program is free software; you can redistribute it and/or modify it under
  3. * the terms of the GNU General Public License as published by the Free Software
  4. * Foundation; version 2 of the License.
  5. *
  6. * This Program is distributed in the hope that it will be useful, but WITHOUT
  7. * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
  8. * FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
  9. *
  10. * You should have received a copy of the GNU General Public License along with
  11. * this Program; if not, write to the Free Software Foundation, Inc., 59 Temple
  12. * Place, Suite 330, Boston, MA 02111-1307 USA.
  13. *
  14. * In addition, as a special exception, Red Hat, Inc. gives You the additional
  15. * right to link the code of this Program with code not covered under the GNU
  16. * General Public License ("Non-GPL Code") and to distribute linked combinations
  17. * including the two, subject to the limitations in this paragraph. Non-GPL Code
  18. * permitted under this exception must only link to the code of this Program
  19. * through those well defined interfaces identified in the file named EXCEPTION
  20. * found in the source code files (the "Approved Interfaces"). The files of
  21. * Non-GPL Code may instantiate templates or use macros or inline functions from
  22. * the Approved Interfaces without causing the resulting work to be covered by
  23. * the GNU General Public License. Only Red Hat, Inc. may make changes or
  24. * additions to the list of Approved Interfaces. You must obey the GNU General
  25. * Public License in all respects for all of the Program code and other code used
  26. * in conjunction with the Program except the Non-GPL Code covered by this
  27. * exception. If you modify this file, you may extend this exception to your
  28. * version of the file, but you are not obligated to do so. If you do not wish to
  29. * provide this exception without modification, you must delete this exception
  30. * statement from your version and license this file solely under the GPL without
  31. * exception.
  32. *
  33. *
  34. * Copyright (C) 2008 Red Hat, Inc.
  35. * All rights reserved.
  36. * END COPYRIGHT BLOCK **/
  37. #ifndef WINSYNC_PLUGIN_PUBLIC_API
  38. #define WINSYNC_PLUGIN_PUBLIC_API
  39. #ifdef HAVE_CONFIG_H
  40. # include <config.h>
  41. #endif
  42. /* windows_private.c */
  43. #include "slapi-plugin.h"
  44. /*
  45. * WinSync plug-in API
  46. */
  47. #define WINSYNC_v1_0_GUID "CDA8F029-A3C6-4EBB-80B8-A2E183DB0481"
  48. /*
  49. * This callback is called when a winsync agreement is created.
  50. * The ds_subtree and ad_subtree from the agreement are read-only.
  51. * The callback can allocate some private data to return. If so
  52. * the callback must define a winsync_plugin_destroy_agmt_cb so
  53. * that the private data can be freed. This private data is passed
  54. * to every other callback function as the void *cookie argument.
  55. */
  56. typedef void * (*winsync_plugin_init_cb)(const Slapi_DN *ds_subtree, const Slapi_DN *ad_subtree);
  57. #define WINSYNC_PLUGIN_INIT_CB 1
  58. /* agmt_dn - const - the original AD base dn from the winsync agreement
  59. scope - set directly e.g. *scope = 42;
  60. base, filter - malloced - to set, free first e.g.
  61. slapi_ch_free_string(filter);
  62. *base = slapi_ch_strdup("(objectclass=foobar)");
  63. winsync code will use slapi_ch_free_string to free this value, so no static strings
  64. attrs - NULL or null terminated array of strings - can use slapi_ch_array_add to add e.g.
  65. slapi_ch_array_add(attrs, slapi_ch_strdup("myattr"));
  66. attrs will be freed with slapi_ch_array_free, so caller must own the memory
  67. serverctrls - NULL or null terminated array of LDAPControl* - can use slapi_add_control_ext to add
  68. slapi_add_control_ext(serverctrls, mynewctrl, 1 / add a copy /);
  69. serverctrls will be freed with ldap_controls_free, so caller must own memory
  70. */
  71. typedef void (*winsync_search_params_cb)(void *cookie, const char *agmt_dn, char **base, int *scope, char **filter, char ***attrs, LDAPControl ***serverctrls);
  72. #define WINSYNC_PLUGIN_DIRSYNC_SEARCH_CB 2 /* serverctrls will already contain the DirSync control */
  73. #define WINSYNC_PLUGIN_PRE_AD_SEARCH_CB 3
  74. #define WINSYNC_PLUGIN_PRE_DS_SEARCH_ENTRY_CB 4
  75. #define WINSYNC_PLUGIN_PRE_DS_SEARCH_ALL_CB 5
  76. /*
  77. * These callbacks are the main entry points that allow the plugin
  78. * to intercept modifications to local and remote entries.
  79. * rawentry - the raw AD entry, read directly from AD - this is read only
  80. * ad_entry - the "cooked" AD entry - the DN in this entry should be set
  81. * when the operation is to modify the AD entry
  82. * ds_entry - the entry from the ds - the DN in this entry should be set
  83. * when the operation is to modify the DS entry
  84. * smods - the post-processing modifications - these should be modified
  85. * by the plugin as needed
  86. * do_modify - if the code has some modifications that need to be applied, this
  87. * will be set to true - if the plugin has added some items to smods
  88. * this should be set to true - if the plugin has removed all of
  89. * the smods, and no operation should be performed, this should
  90. * be set to false
  91. */
  92. typedef void (*winsync_pre_mod_cb)(void *cookie, const Slapi_Entry *rawentry, Slapi_Entry *ad_entry, Slapi_Entry *ds_entry, Slapi_Mods *smods, int *do_modify);
  93. #define WINSYNC_PLUGIN_PRE_AD_MOD_USER_CB 6
  94. #define WINSYNC_PLUGIN_PRE_AD_MOD_GROUP_CB 7
  95. #define WINSYNC_PLUGIN_PRE_DS_MOD_USER_CB 8
  96. #define WINSYNC_PLUGIN_PRE_DS_MOD_GROUP_CB 9
  97. /*
  98. * These callbacks are called when a new entry is being added to the
  99. * local directory server from AD.
  100. * rawentry - the raw AD entry, read directly from AD - this is read only
  101. * ad_entry - the "cooked" AD entry
  102. * ds_entry - the entry to be added to the DS - all modifications should
  103. * be made to this entry, including changing the DN if needed,
  104. * since the DN of this entry will be used as the ADD target DN
  105. * This entry will already have had the default schema mapping applied
  106. */
  107. typedef void (*winsync_pre_add_cb)(void *cookie, const Slapi_Entry *rawentry, Slapi_Entry *ad_entry, Slapi_Entry *ds_entry);
  108. #define WINSYNC_PLUGIN_PRE_DS_ADD_USER_CB 10
  109. #define WINSYNC_PLUGIN_PRE_DS_ADD_GROUP_CB 11
  110. /*
  111. * If a new entry has been added to AD, and we're sync'ing it over
  112. * to the DS, we may need to create a new DN for the entry. The
  113. * code tries to come up with a reasonable DN, but the plugin may
  114. * have different ideas. These callbacks allow the plugin to specify
  115. * what the new DN for the new entry should be. This is called from
  116. * map_entry_dn_inbound which is called from various places where the DN for
  117. * the new entry is needed. The winsync_plugin_call_pre_ds_add_* callbacks
  118. * can also be used to set the DN just before the entry is stored in the DS.
  119. * This is also used when we are mapping a dn valued attribute e.g. owner
  120. * or secretary
  121. * rawentry - the raw AD entry, read directly from AD - this is read only
  122. * ad_entry - the "cooked" AD entry
  123. * new_dn_string - the given value will be the default value created by the sync code
  124. * to change it, slapi_ch_free_string first, then malloc the value to use
  125. * ds_suffix - the suffix from the DS side of the sync agreement
  126. * ad_suffix - the suffix from the AD side of the sync agreement
  127. */
  128. typedef void (*winsync_get_new_dn_cb)(void *cookie, const Slapi_Entry *rawentry, Slapi_Entry *ad_entry, char **new_dn_string,
  129. const Slapi_DN *ds_suffix, const Slapi_DN *ad_suffix);
  130. #define WINSYNC_PLUGIN_GET_NEW_DS_USER_DN_CB 12
  131. #define WINSYNC_PLUGIN_GET_NEW_DS_GROUP_DN_CB 13
  132. /*
  133. * These callbacks are called when a mod operation is going to be replayed
  134. * to AD. This case is different than the pre add or pre mod callbacks
  135. * above because in this context, we may only have the list of modifications
  136. * and the DN to which the mods were applied.
  137. * rawentry - the raw AD entry, read directly from AD - may be NULL
  138. * local_dn - the original local DN used in the modification
  139. * origmods - the original mod list
  140. * remote_dn - this is the DN which will be used with the remote modify operation
  141. * to AD - the winsync code may have already attempted to calculate its value
  142. * modstosend - this is the list of modifications which will be sent - the winsync
  143. * code will already have done its default mapping to these values
  144. *
  145. */
  146. typedef void (*winsync_pre_ad_mod_mods_cb)(void *cookie, const Slapi_Entry *rawentry, const Slapi_DN *local_dn, LDAPMod * const *origmods, Slapi_DN *remote_dn, LDAPMod ***modstosend);
  147. #define WINSYNC_PLUGIN_PRE_AD_MOD_USER_MODS_CB 14
  148. #define WINSYNC_PLUGIN_PRE_AD_MOD_GROUP_MODS_CB 15
  149. /*
  150. * Callbacks used to determine if an entry should be added to the
  151. * AD side if it does not already exist.
  152. * local_entry - the candidate entry to test
  153. * remote_DN - the candidate remote entry to add
  154. */
  155. typedef int (*winsync_can_add_to_ad_cb)(void *cookie, const Slapi_Entry *local_entry, const Slapi_DN *remote_dn);
  156. #define WINSYNC_PLUGIN_CAN_ADD_ENTRY_TO_AD_CB 16
  157. /*
  158. * Callbacks called at begin and end of update
  159. *
  160. * The ds subtree and the ad subtree from the sync agreement are passed in.
  161. * These are read only.
  162. * is_total will be true if this is a total update, or false if this
  163. * is an incremental update
  164. */
  165. typedef void (*winsync_plugin_update_cb)(void *cookie, const Slapi_DN *ds_subtree, const Slapi_DN *ad_subtree, int is_total);
  166. #define WINSYNC_PLUGIN_BEGIN_UPDATE_CB 17
  167. #define WINSYNC_PLUGIN_END_UPDATE_CB 18
  168. /*
  169. * Callbacks called when the agreement is destroyed.
  170. *
  171. * The ds subtree and the ad subtree from the sync agreement are passed in.
  172. * These are read only.
  173. * The plugin must define this function to free the cookie allocated
  174. * in the init function, if any.
  175. */
  176. typedef void (*winsync_plugin_destroy_agmt_cb)(void *cookie, const Slapi_DN *ds_subtree, const Slapi_DN *ad_subtree);
  177. #define WINSYNC_PLUGIN_DESTROY_AGMT_CB 19
  178. /*
  179. The following are sample code stubs to show how to implement
  180. a plugin which uses this api
  181. */
  182. #ifdef WINSYNC_SAMPLE_CODE
  183. #include "slapi-plugin.h"
  184. #include "winsync-plugin.h"
  185. static char *test_winsync_plugin_name = "test_winsync_api";
  186. static void *
  187. test_winsync_api_init(const Slapi_DN *ds_subtree, const Slapi_DN *ad_subtree)
  188. {
  189. slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
  190. "--> test_winsync_init [%s] [%s] -- begin\n",
  191. slapi_sdn_get_dn(ds_subtree),
  192. slapi_sdn_get_dn(ad_subtree));
  193. slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
  194. "<-- test_winsync_init -- end\n");
  195. return NULL;
  196. }
  197. static void
  198. test_winsync_dirsync_search_params_cb(void *cbdata, const char *agmt_dn,
  199. char **base, int *scope, char **filter,
  200. char ***attrs, LDAPControl ***serverctrls)
  201. {
  202. slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
  203. "--> test_winsync_dirsync_search_params_cb -- begin\n");
  204. slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
  205. "<-- test_winsync_dirsync_search_params_cb -- end\n");
  206. return;
  207. }
  208. /* called before searching for a single entry from AD - agmt_dn will be NULL */
  209. static void
  210. test_winsync_pre_ad_search_cb(void *cbdata, const char *agmt_dn,
  211. char **base, int *scope, char **filter,
  212. char ***attrs, LDAPControl ***serverctrls)
  213. {
  214. slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
  215. "--> test_winsync_pre_ad_search_cb -- begin\n");
  216. slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
  217. "<-- test_winsync_pre_ad_search_cb -- end\n");
  218. return;
  219. }
  220. /* called before an internal search to get a single DS entry - agmt_dn will be NULL */
  221. static void
  222. test_winsync_pre_ds_search_entry_cb(void *cbdata, const char *agmt_dn,
  223. char **base, int *scope, char **filter,
  224. char ***attrs, LDAPControl ***serverctrls)
  225. {
  226. slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
  227. "--> test_winsync_pre_ds_search_cb -- begin\n");
  228. slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
  229. "<-- test_winsync_pre_ds_search_cb -- end\n");
  230. return;
  231. }
  232. /* called before the total update to get all entries from the DS to sync to AD */
  233. static void
  234. test_winsync_pre_ds_search_all_cb(void *cbdata, const char *agmt_dn,
  235. char **base, int *scope, char **filter,
  236. char ***attrs, LDAPControl ***serverctrls)
  237. {
  238. slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
  239. "--> test_winsync_pre_ds_search_all_cb -- orig filter [%s] -- begin\n",
  240. ((filter && *filter) ? *filter : "NULL"));
  241. /* We only want to grab users from the ds side - no groups */
  242. slapi_ch_free_string(filter);
  243. /* maybe use ntUniqueId=* - only get users that have already been
  244. synced with AD already - ntUniqueId and ntUserDomainId are
  245. indexed for equality only - need to add presence? */
  246. *filter = slapi_ch_strdup("(&(objectclass=ntuser)(ntUserDomainId=*))");
  247. slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
  248. "<-- test_winsync_pre_ds_search_all_cb -- end\n");
  249. return;
  250. }
  251. static void
  252. test_winsync_pre_ad_mod_user_cb(void *cbdata, const Slapi_Entry *rawentry,
  253. Slapi_Entry *ad_entry, Slapi_Entry *ds_entry,
  254. Slapi_Mods *smods, int *do_modify)
  255. {
  256. slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
  257. "--> test_winsync_pre_ad_mod_user_cb -- begin\n");
  258. slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
  259. "<-- test_winsync_pre_ad_mod_user_cb -- end\n");
  260. return;
  261. }
  262. static void
  263. test_winsync_pre_ad_mod_group_cb(void *cbdata, const Slapi_Entry *rawentry,
  264. Slapi_Entry *ad_entry, Slapi_Entry *ds_entry,
  265. Slapi_Mods *smods, int *do_modify)
  266. {
  267. slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
  268. "--> test_winsync_pre_ad_mod_group_cb -- begin\n");
  269. slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
  270. "<-- test_winsync_pre_ad_mod_group_cb -- end\n");
  271. return;
  272. }
  273. static void
  274. test_winsync_pre_ds_mod_user_cb(void *cbdata, const Slapi_Entry *rawentry,
  275. Slapi_Entry *ad_entry, Slapi_Entry *ds_entry,
  276. Slapi_Mods *smods, int *do_modify)
  277. {
  278. slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
  279. "--> test_winsync_pre_ds_mod_user_cb -- begin\n");
  280. slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
  281. "<-- test_winsync_pre_ds_mod_user_cb -- end\n");
  282. return;
  283. }
  284. static void
  285. test_winsync_pre_ds_mod_group_cb(void *cbdata, const Slapi_Entry *rawentry,
  286. Slapi_Entry *ad_entry, Slapi_Entry *ds_entry,
  287. Slapi_Mods *smods, int *do_modify)
  288. {
  289. slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
  290. "--> test_winsync_pre_ds_mod_group_cb -- begin\n");
  291. slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
  292. "<-- test_winsync_pre_ds_mod_group_cb -- end\n");
  293. return;
  294. }
  295. static void
  296. test_winsync_pre_ds_add_user_cb(void *cbdata, const Slapi_Entry *rawentry,
  297. Slapi_Entry *ad_entry, Slapi_Entry *ds_entry)
  298. {
  299. slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
  300. "--> test_winsync_pre_ds_add_user_cb -- begin\n");
  301. slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
  302. "<-- test_winsync_pre_ds_add_user_cb -- end\n");
  303. return;
  304. }
  305. static void
  306. test_winsync_pre_ds_add_group_cb(void *cbdata, const Slapi_Entry *rawentry,
  307. Slapi_Entry *ad_entry, Slapi_Entry *ds_entry)
  308. {
  309. slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
  310. "--> test_winsync_pre_ds_add_group_cb -- begin\n");
  311. slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
  312. "<-- test_winsync_pre_ds_add_group_cb -- end\n");
  313. return;
  314. }
  315. static void
  316. test_winsync_get_new_ds_user_dn_cb(void *cbdata, const Slapi_Entry *rawentry,
  317. Slapi_Entry *ad_entry, char **new_dn_string,
  318. const Slapi_DN *ds_suffix, const Slapi_DN *ad_suffix)
  319. {
  320. char **rdns = NULL;
  321. slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
  322. "--> test_winsync_get_new_ds_user_dn_cb -- old dn [%s] -- begin\n",
  323. *new_dn_string);
  324. rdns = ldap_explode_dn(*new_dn_string, 0);
  325. if (!rdns || !rdns[0]) {
  326. ldap_value_free(rdns);
  327. return;
  328. }
  329. slapi_ch_free_string(new_dn_string);
  330. *new_dn_string = PR_smprintf("%s,%s", rdns[0], slapi_sdn_get_dn(ds_suffix));
  331. ldap_value_free(rdns);
  332. slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
  333. "<-- test_winsync_get_new_ds_user_dn_cb -- new dn [%s] -- end\n",
  334. *new_dn_string);
  335. return;
  336. }
  337. static void
  338. test_winsync_get_new_ds_group_dn_cb(void *cbdata, const Slapi_Entry *rawentry,
  339. Slapi_Entry *ad_entry, char **new_dn_string,
  340. const Slapi_DN *ds_suffix, const Slapi_DN *ad_suffix)
  341. {
  342. slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
  343. "--> test_winsync_get_new_ds_group_dn_cb -- begin\n");
  344. slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
  345. "<-- test_winsync_get_new_ds_group_dn_cb -- end\n");
  346. return;
  347. }
  348. static void
  349. test_winsync_pre_ad_mod_user_mods_cb(void *cbdata, const Slapi_Entry *rawentry,
  350. const Slapi_DN *local_dn, LDAPMod * const *origmods,
  351. Slapi_DN *remote_dn, LDAPMod ***modstosend)
  352. {
  353. slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
  354. "--> test_winsync_pre_ad_mod_user_mods_cb -- begin\n");
  355. slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
  356. "<-- test_winsync_pre_ad_mod_user_mods_cb -- end\n");
  357. return;
  358. }
  359. static void
  360. test_winsync_pre_ad_mod_group_mods_cb(void *cbdata, const Slapi_Entry *rawentry,
  361. const Slapi_DN *local_dn, LDAPMod * const *origmods,
  362. Slapi_DN *remote_dn, LDAPMod ***modstosend)
  363. {
  364. slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
  365. "--> test_winsync_pre_ad_mod_group_mods_cb -- begin\n");
  366. slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
  367. "<-- test_winsync_pre_ad_mod_group_mods_cb -- end\n");
  368. return;
  369. }
  370. static int
  371. test_winsync_can_add_entry_to_ad_cb(void *cbdata, const Slapi_Entry *local_entry,
  372. const Slapi_DN *remote_dn)
  373. {
  374. slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
  375. "--> test_winsync_can_add_entry_to_ad_cb -- begin\n");
  376. slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
  377. "<-- test_winsync_can_add_entry_to_ad_cb -- end\n");
  378. return 0; /* false - do not allow entries to be added to ad */
  379. }
  380. static void
  381. test_winsync_begin_update_cb(void *cbdata, const Slapi_DN *ds_subtree,
  382. const Slapi_DN *ad_subtree, int is_total)
  383. {
  384. slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
  385. "--> test_winsync_begin_update_cb -- begin\n");
  386. slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
  387. "<-- test_winsync_begin_update_cb -- end\n");
  388. return;
  389. }
  390. static void
  391. test_winsync_end_update_cb(void *cbdata, const Slapi_DN *ds_subtree,
  392. const Slapi_DN *ad_subtree, int is_total)
  393. {
  394. slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
  395. "--> test_winsync_end_update_cb -- begin\n");
  396. slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
  397. "<-- test_winsync_end_update_cb -- end\n");
  398. return;
  399. }
  400. static void
  401. test_winsync_destroy_agmt_cb(void *cbdata, const Slapi_DN *ds_subtree,
  402. const Slapi_DN *ad_subtree)
  403. {
  404. slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
  405. "--> test_winsync_destroy_agmt_cb -- begin\n");
  406. /* free(cbdata); */
  407. slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
  408. "<-- test_winsync_destroy_agmt_cb -- end\n");
  409. return;
  410. }
  411. /**
  412. * Plugin identifiers
  413. */
  414. static Slapi_PluginDesc test_winsync_pdesc = {
  415. "test-winsync-plugin",
  416. PLUGIN_MAGIC_VENDOR_STR,
  417. PRODUCTTEXT,
  418. "test winsync plugin"
  419. };
  420. static Slapi_ComponentId *test_winsync_plugin_id = NULL;
  421. static void *test_winsync_api[] = {
  422. NULL, /* reserved for api broker use, must be zero */
  423. test_winsync_api_init,
  424. test_winsync_dirsync_search_params_cb,
  425. test_winsync_pre_ad_search_cb,
  426. test_winsync_pre_ds_search_entry_cb,
  427. test_winsync_pre_ds_search_all_cb,
  428. test_winsync_pre_ad_mod_user_cb,
  429. test_winsync_pre_ad_mod_group_cb,
  430. test_winsync_pre_ds_mod_user_cb,
  431. test_winsync_pre_ds_mod_group_cb,
  432. test_winsync_pre_ds_add_user_cb,
  433. test_winsync_pre_ds_add_group_cb,
  434. test_winsync_get_new_ds_user_dn_cb,
  435. test_winsync_get_new_ds_group_dn_cb,
  436. test_winsync_pre_ad_mod_user_mods_cb,
  437. test_winsync_pre_ad_mod_group_mods_cb,
  438. test_winsync_can_add_entry_to_ad_cb,
  439. test_winsync_begin_update_cb,
  440. test_winsync_end_update_cb,
  441. test_winsync_destroy_agmt_cb
  442. };
  443. static int
  444. test_winsync_plugin_start(Slapi_PBlock *pb)
  445. {
  446. slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
  447. "--> test_winsync_plugin_start -- begin\n");
  448. if( slapi_apib_register(WINSYNC_v1_0_GUID, test_winsync_api) ) {
  449. slapi_log_error( SLAPI_LOG_FATAL, test_winsync_plugin_name,
  450. "<-- test_winsync_plugin_start -- failed to register winsync api -- end\n");
  451. return -1;
  452. }
  453. slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
  454. "<-- test_winsync_plugin_start -- end\n");
  455. return 0;
  456. }
  457. static int
  458. test_winsync_plugin_close(Slapi_PBlock *pb)
  459. {
  460. slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
  461. "--> test_winsync_plugin_close -- begin\n");
  462. slapi_apib_unregister(WINSYNC_v1_0_GUID);
  463. slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
  464. "<-- test_winsync_plugin_close -- end\n");
  465. return 0;
  466. }
  467. /* this is the slapi plugin init function,
  468. not the one used by the winsync api
  469. */
  470. int test_winsync_plugin_init(Slapi_PBlock *pb)
  471. {
  472. slapi_log_error(SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
  473. "--> test_winsync_plugin_init -- begin\n");
  474. if ( slapi_pblock_set( pb, SLAPI_PLUGIN_VERSION,
  475. SLAPI_PLUGIN_VERSION_01 ) != 0 ||
  476. slapi_pblock_set(pb, SLAPI_PLUGIN_START_FN,
  477. (void *) test_winsync_plugin_start ) != 0 ||
  478. slapi_pblock_set(pb, SLAPI_PLUGIN_CLOSE_FN,
  479. (void *) test_winsync_plugin_close ) != 0 ||
  480. slapi_pblock_set( pb, SLAPI_PLUGIN_DESCRIPTION,
  481. (void *)&test_winsync_pdesc ) != 0 )
  482. {
  483. slapi_log_error( SLAPI_LOG_FATAL, test_winsync_plugin_name,
  484. "<-- test_winsync_plugin_init -- failed to register plugin -- end\n");
  485. return -1;
  486. }
  487. /* Retrieve and save the plugin identity to later pass to
  488. internal operations */
  489. if (slapi_pblock_get(pb, SLAPI_PLUGIN_IDENTITY, &test_winsync_plugin_id) != 0) {
  490. slapi_log_error(SLAPI_LOG_FATAL, test_winsync_plugin_name,
  491. "<-- test_winsync_plugin_init -- failed to retrieve plugin identity -- end\n");
  492. return -1;
  493. }
  494. slapi_log_error( SLAPI_LOG_PLUGIN, test_winsync_plugin_name,
  495. "<-- test_winsync_plugin_init -- end\n");
  496. return 0;
  497. }
  498. /*
  499. dn: cn=Test Winsync API,cn=plugins,cn=config
  500. objectclass: top
  501. objectclass: nsSlapdPlugin
  502. objectclass: extensibleObject
  503. cn: Test Winsync API
  504. nsslapd-pluginpath: libtestwinsync-plugin
  505. nsslapd-plugininitfunc: test_winsync_plugin_init
  506. nsslapd-plugintype: preoperation
  507. nsslapd-pluginenabled: on
  508. nsslapd-plugin-depends-on-type: database
  509. nsslapd-plugin-depends-on-named: Multimaster Replication Plugin
  510. */
  511. #endif /* WINSYNC_SAMPLE_CODE */
  512. #endif /* WINSYNC_PLUGIN_PUBLIC_API */