mirror of
https://git.openldap.org/openldap/openldap.git
synced 2024-12-21 03:10:25 +08:00
f11c6b27e7
Now related ITSes need be audited and possibly closed. Enhancements: - re-styled code for better readability - upgraded backend API to reflect recent changes - LDAP schema is checked when loading SQL/LDAP mapping - AttributeDescription/ObjectClass pointers used for more efficient mapping lookup - bervals used where string length is required often - atomized write operations by committing at the end of each operation and defaulting connection closure to rollback - added LDAP access control to write operations - fully implemented modrdn (with rdn attrs change, deleteoldrdn, access check, parent/children check and more) - added parent access control, children control to delete operation - added structuralObjectClass operational attribute check and value return on search - added hasSubordinate operational attribute on demand - search limits are appropriately enforced - function backsql_strcat() has been made more efficient - concat function has been made configurable by means of a pattern - added config switches: - fail_if_no_mapping write operations fail if there is no mapping - has_ldapinfo_dn_ru overrides autodetect - concat_pattern a string containing two '?' is used (note that "?||?" should be more portable than builtin function "CONCAT(?,?)") - strcast_func cast of string constants in "SELECT DISTINCT statements (needed by PostgreSQL) - upper_needs_cast cast the argument of upper when required (basically when building dn substring queries) Todo: - add security checks for SQL statements that can be injected (?) - re-test with previously supported RDBMs - replace dn_ru and so with normalized dn (no need for upper() and so in dn match) - implement a backsql_normalize() function to replace the upper() conversion routines - note that subtree deletion, subtree renaming and so could be easily implemented (rollback and consistency checks are available :) - implement "lastmod" and other operational stuff (ldap_entries table ?)
84 lines
2.4 KiB
C
84 lines
2.4 KiB
C
#ifndef __BACKSQL_UTIL_H__
|
|
#define __BACKSQL_UTIL_H__
|
|
|
|
/*
|
|
* Copyright 1999, Dmitry Kovalev <mit@openldap.org>, All rights reserved.
|
|
*
|
|
* Redistribution and use in source and binary forms are permitted only
|
|
* as authorized by the OpenLDAP Public License. A copy of this
|
|
* license is available at http://www.OpenLDAP.org/license.html or
|
|
* in file LICENSE in the top-level directory of the distribution.
|
|
*/
|
|
|
|
|
|
#include "entry-id.h"
|
|
#include "schema-map.h"
|
|
|
|
#define BACKSQL_CONCAT
|
|
|
|
struct berval * backsql_strcat( struct berval *dest, ber_len_t *buflen, ... );
|
|
struct berval * backsql_strfcat( struct berval *dest, ber_len_t *buflen,
|
|
const char *fmt, ... );
|
|
|
|
int backsql_entry_addattr( Entry *e, struct berval *at_name,
|
|
struct berval *at_val );
|
|
|
|
typedef struct backsql_srch_info {
|
|
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;
|
|
backsql_info *bi;
|
|
backsql_oc_map_rec *oc;
|
|
struct berval sel, from, join_where, flt_where;
|
|
ber_len_t sel_len, from_len, jwhere_len, fwhere_len;
|
|
SQLHDBC dbh;
|
|
int status;
|
|
Backend *be;
|
|
Connection *conn;
|
|
Operation *op;
|
|
AttributeName *attrs;
|
|
int attr_flags;
|
|
#define BSQL_SF_ALL_OPER 0x0001
|
|
Entry *e;
|
|
/* 1 if the db is TimesTen; 0 if it's not */
|
|
int use_reverse_dn;
|
|
} backsql_srch_info;
|
|
|
|
int backsql_process_filter( backsql_srch_info *bsi, Filter *f );
|
|
void backsql_init_search( backsql_srch_info *bsi, backsql_info *bi,
|
|
struct berval *nbase, int scope, int slimit, int tlimit,
|
|
time_t stoptime, Filter *filter, SQLHDBC dbh,
|
|
BackendDB *be, Connection *conn, 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 berval *dest_from, ber_len_t *dest_len,
|
|
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__ */
|
|
|