]> git.sur5r.net Git - openldap/blobdiff - servers/slapd/back-sql/util.h
remove dnNormalize2
[openldap] / servers / slapd / back-sql / util.h
index 1fe0cbab2cb2077043bef5f9a4baf26d4f468a8f..a510a604aa05fff0a32f8447af436dbbcaefa569 100644 (file)
 #include "entry-id.h"
 #include "schema-map.h"
 
-#define BACKSQL_MAX(a,b) ((a)>(b)?(a):(b))
-#define BACKSQL_MIN(a,b) ((a)<(b)?(a):(b))
-
-#define BACKSQL_STR_GROW 64
-
-char* backsql_strcat(char* dest,int *buflen, ...);
-
-int backsql_entry_addattr(Entry *e,char *at_name,char *at_val,unsigned int at_val_len);
-
-typedef struct __backsql_srch_info
-{
- char *base_dn;
- int scope;
- Filter *filter;
- int slimit,tlimit;
- time_t        stoptime;
- backsql_entryID *id_list,*c_eid;
- int abandon;
- backsql_info *bi;
- backsql_oc_map_rec *oc;
- char *sel,*from,*join_where,*flt_where;
- int sel_len,from_len,jwhere_len,fwhere_len;
- SQLHDBC dbh;
- int status;
- Backend *be;
- Connection *conn;
- Operation *op;
- char **attrs;
- Entry *e;
-}backsql_srch_info;
-
-int backsql_process_filter(backsql_srch_info *bsi,Filter *f);
-void backsql_init_search(backsql_srch_info *bsi,backsql_info *bi,char *nbase,int scope,
-                                                int slimit,int tlimit,time_t stoptime,Filter *filter,
-                                                SQLHDBC dbh,Backend *be,Connection *conn,Operation *op,char **attrs);
-Entry* backsql_id2entry(backsql_srch_info *bsi,Entry* e,backsql_entryID* id);
-
-extern char backsql_def_oc_query[],backsql_def_at_query[],
-                       backsql_def_delentry_query[],backsql_def_insentry_query[],
-                       backsql_def_subtree_cond[],backsql_id_query[];
-
-int backsql_merge_from_clause(char **dest_from,int *dest_len,char *src_from);
-
-#endif
\ No newline at end of file
+#define BACKSQL_CONCAT
+
+typedef struct berbuf {
+       struct berval   bb_val;
+       ber_len_t       bb_len;
+} BerBuffer;
+#define BB_NULL                { { 0, NULL }, 0 }
+
+struct berbuf * backsql_strcat( struct berbuf *dest, ... );
+struct berbuf * backsql_strfcat( struct berbuf *dest, const char *fmt, ... );
+
+int backsql_entry_addattr( Entry *e, struct berval *at_name, 
+               struct berval *at_val, void *memctx );
+
+typedef struct backsql_srch_info {
+       Operation               *op;
+
+       int                     bsi_flags;
+#define        BSQL_SF_ALL_OPER                0x0001
+#define BSQL_SF_FILTER_HASSUBORDINATE  0x0002
+
+       struct berval           *base_dn;
+       int                     scope;
+       Filter                  *filter;
+       int                     slimit, tlimit;
+       time_t                  stoptime;
+
+       backsql_entryID         *id_list, *c_eid;
+       int                     n_candidates;
+       int                     abandon;
+       int                     status;
+
+       backsql_oc_map_rec      *oc;
+       struct berbuf           sel, from, join_where, flt_where;
+       SQLHDBC                 dbh;
+       AttributeName           *attrs;
+
+       Entry                   *e;
+} backsql_srch_info;
+
+void backsql_init_search( backsql_srch_info *bsi, 
+               struct berval *nbase, int scope, int slimit, int tlimit,
+               time_t stoptime, Filter *filter, SQLHDBC dbh,
+               Operation *op, AttributeName *attrs );
+Entry *backsql_id2entry( backsql_srch_info *bsi, Entry *e, 
+               backsql_entryID *id );
+
+extern char 
+       backsql_def_oc_query[],
+       backsql_def_needs_select_oc_query[],
+       backsql_def_at_query[],
+       backsql_def_delentry_query[],
+       backsql_def_insentry_query[],
+       backsql_def_subtree_cond[],
+       backsql_def_upper_subtree_cond[],
+       backsql_id_query[],
+       backsql_def_concat_func[];
+extern char 
+       backsql_check_dn_ru_query[];
+
+int backsql_merge_from_clause( struct berbuf *dest_from, 
+               struct berval *src_from );
+
+int backsql_split_pattern( const char *pattern, BerVarray *split_pattern,
+               int expected );
+int backsql_prepare_pattern( BerVarray split_pattern, BerVarray values,
+               struct berval *res );
+
+#endif /* __BACKSQL_UTIL_H__ */
+