mirror of
https://git.openldap.org/openldap/openldap.git
synced 2025-01-12 10:54:48 +08:00
More DS 5.x harmonisation
This commit is contained in:
parent
921d62c2ae
commit
c76d37313b
@ -314,6 +314,178 @@ slapi_entry_attr_get_charptr( const Slapi_Entry *e, const char *type )
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int
|
||||||
|
slapi_entry_attr_get_int( const Slapi_Entry *e, const char *type )
|
||||||
|
{
|
||||||
|
#ifdef LDAP_SLAPI
|
||||||
|
AttributeDescription *ad = NULL;
|
||||||
|
const char *text;
|
||||||
|
int rc;
|
||||||
|
Attribute *attr;
|
||||||
|
|
||||||
|
rc = slap_str2ad( type, &ad, &text );
|
||||||
|
if ( rc != LDAP_SUCCESS ) {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
attr = attr_find( e->e_attrs, ad );
|
||||||
|
if ( attr == NULL ) {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
return slapi_value_get_int( attr->a_vals );
|
||||||
|
#else
|
||||||
|
return 0;
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
int
|
||||||
|
slapi_entry_attr_get_long( const Slapi_Entry *e, const char *type )
|
||||||
|
{
|
||||||
|
#ifdef LDAP_SLAPI
|
||||||
|
AttributeDescription *ad = NULL;
|
||||||
|
const char *text;
|
||||||
|
int rc;
|
||||||
|
Attribute *attr;
|
||||||
|
|
||||||
|
rc = slap_str2ad( type, &ad, &text );
|
||||||
|
if ( rc != LDAP_SUCCESS ) {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
attr = attr_find( e->e_attrs, ad );
|
||||||
|
if ( attr == NULL ) {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
return slapi_value_get_long( attr->a_vals );
|
||||||
|
#else
|
||||||
|
return 0;
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
int
|
||||||
|
slapi_entry_attr_get_uint( const Slapi_Entry *e, const char *type )
|
||||||
|
{
|
||||||
|
#ifdef LDAP_SLAPI
|
||||||
|
AttributeDescription *ad = NULL;
|
||||||
|
const char *text;
|
||||||
|
int rc;
|
||||||
|
Attribute *attr;
|
||||||
|
|
||||||
|
rc = slap_str2ad( type, &ad, &text );
|
||||||
|
if ( rc != LDAP_SUCCESS ) {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
attr = attr_find( e->e_attrs, ad );
|
||||||
|
if ( attr == NULL ) {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
return slapi_value_get_uint( attr->a_vals );
|
||||||
|
#else
|
||||||
|
return 0;
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
int
|
||||||
|
slapi_entry_attr_get_ulong( const Slapi_Entry *e, const char *type )
|
||||||
|
{
|
||||||
|
#ifdef LDAP_SLAPI
|
||||||
|
AttributeDescription *ad = NULL;
|
||||||
|
const char *text;
|
||||||
|
int rc;
|
||||||
|
Attribute *attr;
|
||||||
|
|
||||||
|
rc = slap_str2ad( type, &ad, &text );
|
||||||
|
if ( rc != LDAP_SUCCESS ) {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
attr = attr_find( e->e_attrs, ad );
|
||||||
|
if ( attr == NULL ) {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
return slapi_value_get_ulong( attr->a_vals );
|
||||||
|
#else
|
||||||
|
return 0;
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
int
|
||||||
|
slapi_entry_attr_hasvalue( Slapi_Entry *e, const char *type, const char *value )
|
||||||
|
{
|
||||||
|
#ifdef LDAP_SLAPI
|
||||||
|
struct berval bv;
|
||||||
|
AttributeDescription *ad;
|
||||||
|
const char *text;
|
||||||
|
int rc;
|
||||||
|
Attribute *attr;
|
||||||
|
|
||||||
|
rc = slap_str2ad( type, &ad, &text );
|
||||||
|
if ( rc != LDAP_SUCCESS ) {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
attr = attr_find( e->e_attrs, ad );
|
||||||
|
if ( attr == NULL ) {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
bv.bv_val = (char *)value;
|
||||||
|
bv.bv_len = strlen( value );
|
||||||
|
|
||||||
|
return slapi_attr_value_find( attr, &bv );
|
||||||
|
#else
|
||||||
|
return 0;
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
int
|
||||||
|
slapi_entry_attr_merge_sv( Slapi_Entry *e, const char *type, Slapi_Value **vals )
|
||||||
|
{
|
||||||
|
#ifdef LDAP_SLAPI
|
||||||
|
return slapi_entry_attr_merge( e, (char *)type, vals );
|
||||||
|
#else
|
||||||
|
return -1;
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
int
|
||||||
|
slapi_entry_attr_replace_sv( Slapi_Entry *e, const char *type, Slapi_Value **vals )
|
||||||
|
{
|
||||||
|
#ifdef LDAP_SLAPI
|
||||||
|
AttributeDescription *ad;
|
||||||
|
const char *text;
|
||||||
|
int rc;
|
||||||
|
BerVarray bv;
|
||||||
|
|
||||||
|
rc = slap_str2ad( type, &ad, &text );
|
||||||
|
if ( rc != LDAP_SUCCESS ) {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
attr_delete( &e->e_attrs, ad );
|
||||||
|
|
||||||
|
rc = bvptr2obj( vals, &bv );
|
||||||
|
if ( rc != LDAP_SUCCESS ) {
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
rc = attr_merge( e, ad, bv );
|
||||||
|
slapi_ch_free( (void **)&bv );
|
||||||
|
if ( rc != LDAP_SUCCESS ) {
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
#else
|
||||||
|
return -1;
|
||||||
|
#endif /* LDAP_SLAPI */
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* FIXME -- The caller must free the allocated memory.
|
* FIXME -- The caller must free the allocated memory.
|
||||||
* In Netscape they do not have to.
|
* In Netscape they do not have to.
|
||||||
@ -1966,6 +2138,7 @@ int slapi_value_get_int(const Slapi_Value *value)
|
|||||||
{
|
{
|
||||||
#ifdef LDAP_SLAPI
|
#ifdef LDAP_SLAPI
|
||||||
if ( value == NULL ) return 0;
|
if ( value == NULL ) return 0;
|
||||||
|
if ( value->bv_val == NULL ) return 0;
|
||||||
if ( !checkBVString( value ) ) return 0;
|
if ( !checkBVString( value ) ) return 0;
|
||||||
|
|
||||||
return (int)strtol( value->bv_val, NULL, 10 );
|
return (int)strtol( value->bv_val, NULL, 10 );
|
||||||
@ -1978,6 +2151,7 @@ unsigned int slapi_value_get_uint(const Slapi_Value *value)
|
|||||||
{
|
{
|
||||||
#ifdef LDAP_SLAPI
|
#ifdef LDAP_SLAPI
|
||||||
if ( value == NULL ) return 0;
|
if ( value == NULL ) return 0;
|
||||||
|
if ( value->bv_val == NULL ) return 0;
|
||||||
if ( !checkBVString( value ) ) return 0;
|
if ( !checkBVString( value ) ) return 0;
|
||||||
|
|
||||||
return (unsigned int)strtoul( value->bv_val, NULL, 10 );
|
return (unsigned int)strtoul( value->bv_val, NULL, 10 );
|
||||||
@ -1990,6 +2164,7 @@ long slapi_value_get_long(const Slapi_Value *value)
|
|||||||
{
|
{
|
||||||
#ifdef LDAP_SLAPI
|
#ifdef LDAP_SLAPI
|
||||||
if ( value == NULL ) return 0;
|
if ( value == NULL ) return 0;
|
||||||
|
if ( value->bv_val == NULL ) return 0;
|
||||||
if ( !checkBVString( value ) ) return 0;
|
if ( !checkBVString( value ) ) return 0;
|
||||||
|
|
||||||
return strtol( value->bv_val, NULL, 10 );
|
return strtol( value->bv_val, NULL, 10 );
|
||||||
@ -2002,6 +2177,7 @@ unsigned long slapi_value_get_ulong(const Slapi_Value *value)
|
|||||||
{
|
{
|
||||||
#ifdef LDAP_SLAPI
|
#ifdef LDAP_SLAPI
|
||||||
if ( value == NULL ) return 0;
|
if ( value == NULL ) return 0;
|
||||||
|
if ( value->bv_val == NULL ) return 0;
|
||||||
if ( !checkBVString( value ) ) return 0;
|
if ( !checkBVString( value ) ) return 0;
|
||||||
|
|
||||||
return strtoul( value->bv_val, NULL, 10 );
|
return strtoul( value->bv_val, NULL, 10 );
|
||||||
|
@ -49,6 +49,12 @@ int slapi_entry_attr_merge( Slapi_Entry *e, char *type, struct berval **vals );
|
|||||||
int slapi_entry_attr_find( Slapi_Entry *e, char *type, Slapi_Attr **attr );
|
int slapi_entry_attr_find( Slapi_Entry *e, char *type, Slapi_Attr **attr );
|
||||||
char *slapi_entry_attr_get_charptr( const Slapi_Entry *e, const char *type );
|
char *slapi_entry_attr_get_charptr( const Slapi_Entry *e, const char *type );
|
||||||
int slapi_entry_attr_delete( Slapi_Entry *e, char *type );
|
int slapi_entry_attr_delete( Slapi_Entry *e, char *type );
|
||||||
|
int slapi_entry_attr_get_int( const Slapi_Entry *e, const char *type );
|
||||||
|
int slapi_entry_attr_get_long( const Slapi_Entry *e, const char *type );
|
||||||
|
int slapi_entry_attr_get_uint( const Slapi_Entry *e, const char *type );
|
||||||
|
int slapi_entry_attr_get_ulong( const Slapi_Entry *e, const char *type );
|
||||||
|
int slapi_entry_attr_hasvalue( Slapi_Entry *e, const char *type, const char *value );
|
||||||
|
int slapi_entry_attr_merge_sv( Slapi_Entry *e, const char *type, Slapi_Value **vals );
|
||||||
char *slapi_entry_get_dn( Slapi_Entry *e );
|
char *slapi_entry_get_dn( Slapi_Entry *e );
|
||||||
int slapi_x_entry_get_id( Slapi_Entry *e );
|
int slapi_x_entry_get_id( Slapi_Entry *e );
|
||||||
void slapi_entry_set_dn( Slapi_Entry *e, char *dn );
|
void slapi_entry_set_dn( Slapi_Entry *e, char *dn );
|
||||||
|
Loading…
Reference in New Issue
Block a user