sicis.c 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178
  1. /** BEGIN COPYRIGHT BLOCK
  2. * Copyright (C) 2005 Red Hat, Inc.
  3. * All rights reserved.
  4. *
  5. * License: GPL (version 3 or any later version).
  6. * See LICENSE for details.
  7. * END COPYRIGHT BLOCK **/
  8. #ifdef HAVE_CONFIG_H
  9. # include <config.h>
  10. #endif
  11. /*
  12. * sicis.c - space insensitive string syntax routines.
  13. * these strings are also case insensitive.
  14. *
  15. * This is a non-standard syntax. It is only used by the presence plug-in.
  16. * It will be disabled by default unless the presence plug-in is compiled.
  17. */
  18. #include <stdio.h>
  19. #include <string.h>
  20. #include <sys/types.h>
  21. #include "syntax.h"
  22. static int sicis_filter_ava( Slapi_PBlock *pb, struct berval *bvfilter,
  23. Slapi_Value **bvals, int ftype, Slapi_Value **retVal );
  24. static int sicis_filter_sub( Slapi_PBlock *pb, char *initial, char **any,
  25. char *final, Slapi_Value **bvals );
  26. static int sicis_values2keys( Slapi_PBlock *pb, Slapi_Value **val,
  27. Slapi_Value ***ivals, int ftype );
  28. static int sicis_assertion2keys_ava( Slapi_PBlock *pb, Slapi_Value *val,
  29. Slapi_Value ***ivals, int ftype );
  30. static int sicis_assertion2keys_sub( Slapi_PBlock *pb, char *initial,
  31. char **any, char *final, Slapi_Value ***ivals );
  32. static int sicis_compare(struct berval *v1, struct berval *v2);
  33. static void sicis_normalize(
  34. Slapi_PBlock *pb,
  35. char *s,
  36. int trim_spaces,
  37. char **alt
  38. );
  39. /* the first name is the official one from RFC 2252 */
  40. static char *names[] = { "SpaceInsensitiveString",
  41. SPACE_INSENSITIVE_STRING_SYNTAX_OID, 0 };
  42. static Slapi_PluginDesc pdesc = { "spaceinsensitivestring-syntax",
  43. VENDOR, DS_PACKAGE_VERSION,
  44. "space insensitive string attribute syntax plugin" };
  45. int
  46. sicis_init( Slapi_PBlock *pb )
  47. {
  48. int rc, flags;
  49. LDAPDebug( LDAP_DEBUG_PLUGIN, "=> sicis_init\n", 0, 0, 0 );
  50. rc = slapi_pblock_set( pb, SLAPI_PLUGIN_VERSION,
  51. (void *) SLAPI_PLUGIN_VERSION_01 );
  52. rc |= slapi_pblock_set( pb, SLAPI_PLUGIN_DESCRIPTION,
  53. (void *)&pdesc );
  54. rc |= slapi_pblock_set( pb, SLAPI_PLUGIN_SYNTAX_FILTER_AVA,
  55. (void *) sicis_filter_ava );
  56. rc |= slapi_pblock_set( pb, SLAPI_PLUGIN_SYNTAX_FILTER_SUB,
  57. (void *) sicis_filter_sub );
  58. rc |= slapi_pblock_set( pb, SLAPI_PLUGIN_SYNTAX_VALUES2KEYS,
  59. (void *) sicis_values2keys );
  60. rc |= slapi_pblock_set( pb, SLAPI_PLUGIN_SYNTAX_ASSERTION2KEYS_AVA,
  61. (void *) sicis_assertion2keys_ava );
  62. rc |= slapi_pblock_set( pb, SLAPI_PLUGIN_SYNTAX_ASSERTION2KEYS_SUB,
  63. (void *) sicis_assertion2keys_sub );
  64. flags = SLAPI_PLUGIN_SYNTAX_FLAG_ORDERING;
  65. rc |= slapi_pblock_set( pb, SLAPI_PLUGIN_SYNTAX_FLAGS,
  66. (void *) &flags );
  67. rc |= slapi_pblock_set( pb, SLAPI_PLUGIN_SYNTAX_NAMES,
  68. (void *) names );
  69. rc |= slapi_pblock_set( pb, SLAPI_PLUGIN_SYNTAX_OID,
  70. (void *) SPACE_INSENSITIVE_STRING_SYNTAX_OID );
  71. rc |= slapi_pblock_set( pb, SLAPI_PLUGIN_SYNTAX_COMPARE,
  72. (void *) sicis_compare );
  73. rc |= slapi_pblock_set( pb, SLAPI_PLUGIN_SYNTAX_NORMALIZE,
  74. (void *) sicis_normalize );
  75. LDAPDebug( LDAP_DEBUG_PLUGIN, "<= sicis_init %d\n", rc, 0, 0 );
  76. return( rc );
  77. }
  78. static int
  79. sicis_filter_ava(
  80. Slapi_PBlock *pb,
  81. struct berval *bvfilter,
  82. Slapi_Value **bvals,
  83. int ftype,
  84. Slapi_Value **retVal
  85. )
  86. {
  87. int filter_normalized = 0;
  88. int syntax = SYNTAX_SI | SYNTAX_CIS;
  89. if (pb) {
  90. slapi_pblock_get( pb, SLAPI_PLUGIN_SYNTAX_FILTER_NORMALIZED,
  91. &filter_normalized );
  92. if (filter_normalized) {
  93. syntax |= SYNTAX_NORM_FILT;
  94. }
  95. }
  96. return( string_filter_ava( bvfilter, bvals, syntax,
  97. ftype, retVal ) );
  98. }
  99. static int
  100. sicis_filter_sub(
  101. Slapi_PBlock *pb,
  102. char *initial,
  103. char **any,
  104. char *final,
  105. Slapi_Value **bvals
  106. )
  107. {
  108. return( string_filter_sub( pb, initial, any, final, bvals, SYNTAX_SI | SYNTAX_CIS ) );
  109. }
  110. static int
  111. sicis_values2keys(
  112. Slapi_PBlock *pb,
  113. Slapi_Value **vals,
  114. Slapi_Value ***ivals,
  115. int ftype
  116. )
  117. {
  118. return( string_values2keys( pb, vals, ivals, SYNTAX_SI | SYNTAX_CIS,
  119. ftype ) );
  120. }
  121. static int
  122. sicis_assertion2keys_ava(
  123. Slapi_PBlock *pb,
  124. Slapi_Value *val,
  125. Slapi_Value ***ivals,
  126. int ftype
  127. )
  128. {
  129. return(string_assertion2keys_ava( pb, val, ivals,
  130. SYNTAX_SI | SYNTAX_CIS, ftype ));
  131. }
  132. static int
  133. sicis_assertion2keys_sub(
  134. Slapi_PBlock *pb,
  135. char *initial,
  136. char **any,
  137. char *final,
  138. Slapi_Value ***ivals
  139. )
  140. {
  141. return( string_assertion2keys_sub( pb, initial, any, final, ivals,
  142. SYNTAX_SI | SYNTAX_CIS ) );
  143. }
  144. static int sicis_compare(
  145. struct berval *v1,
  146. struct berval *v2
  147. )
  148. {
  149. return value_cmp(v1, v2, SYNTAX_SI|SYNTAX_CIS, 3 /* Normalise both values */);
  150. }
  151. static void sicis_normalize(
  152. Slapi_PBlock *pb,
  153. char *s,
  154. int trim_spaces,
  155. char **alt
  156. )
  157. {
  158. value_normalize_ext(s, SYNTAX_SI|SYNTAX_CIS, trim_spaces, alt);
  159. return;
  160. }