mirror of
https://git.openldap.org/openldap/openldap.git
synced 2025-12-22 23:59:34 -05:00
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 ?)
83 lines
2.4 KiB
C
83 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__ */
|
|
|