openldap/servers/ldapd/association.c
Kurt Zeilenga b5494457d8 Remove extern declarations of library functions from source.c.
This could cause problems on odd systems.  The generic
  headers should be extended as needed to include necessary
  system headers or, if necessary, make explicit declarations.
Extended ac/string.h header to look for string.h/strings.h if
  STDC_HEADERS is not defined.  Also provide basic declarations for
  str*() functions.  This could cause problems on odd systems.
Extended ac/unistd.h header to define basic declaration for misc
  functions that might be missing from headers.   This includes
  externs for getenv(), getopt(), mktemp(), tempname().
Protect fax500.h from multiple inclusion.  Moved includes of
  system/generic headers back to source files.
Made mail500 helper functions static.
Fixed includes of ctype.h, signal.h, etc. to use generics.
lutil/tempname.c: was including stdlib.h twice, one should stdio.h.
Wrapped <sys/resource.h> with HAVE_SYS_RESOURCE_H.
lber/io.c/ber_get_next(): Changed noctets back to signed.
  Used with BerRead which expects signed int as second arg and
  returns signed int.
1998-11-16 05:07:27 +00:00

286 lines
5.7 KiB
C

/*
* Copyright (c) 1990 Regents of the University of Michigan.
* All rights reserved.
*
* Redistribution and use in source and binary forms are permitted
* provided that this notice is preserved and that due credit is given
* to the University of Michigan at Ann Arbor. The name of the University
* may not be used to endorse or promote products derived from this
* software without specific prior written permission. This software
* is provided ``as is'' without express or implied warranty.
*/
#include "portable.h"
#include <stdio.h>
#include <ac/errno.h>
#include <ac/socket.h>
#include <ac/string.h>
#include <ac/time.h>
#include <quipu/commonarg.h>
#include <quipu/ds_error.h>
#include <quipu/dap.h> /* get dap_unbind() */
#if ISODEPACKAGE == IC
#include <ll/isoaddrs.h>
#else
#include <isoaddrs.h>
#endif
#include "lber.h"
#include "ldap.h"
#include "common.h"
#ifdef HAVE_SYS_IOCTL_H
#include <sys/ioctl.h>
#endif
#ifdef HAVE_SYS_FILIO_H
#include <sys/filio.h>
#endif
#ifdef __hpux
#define FIOGETOWN FIOGSAIOOWN
#endif
struct conn *conns;
struct conn *
conn_dup( struct conn *cn )
{
struct conn *new;
if ( (new = (struct conn *) malloc( sizeof(struct conn) )) == NULL )
return( NULL );
*new = *cn;
new->c_next = NULL;
new->c_time = 0L;
new->c_paddr = psap_cpy( cn->c_paddr );
new->c_dn = strdup( cn->c_dn );
if ( new->c_credlen > 0 ) {
new->c_cred = (char *) malloc( cn->c_credlen );
SAFEMEMCPY( new->c_cred, cn->c_cred, cn->c_credlen );
} else {
new->c_cred = "";
}
new->c_credlen = cn->c_credlen;
new->c_refcnt = 1;
return( new );
}
int
conn_init( void )
{
struct PSAPaddr *addr;
if ( (conns = (struct conn *) malloc( sizeof(struct conn) )) == NULL ) {
Debug( LDAP_DEBUG_ANY, "conn_init: malloc failed\n", 0, 0, 0 );
return( -1 );
}
conns->c_ad = -1;
conns->c_dn = NULL;
conns->c_cred = NULL;
conns->c_credlen = 0;
if ( dsa_address == NULL || (addr = str2paddr( dsa_address ))
== NULLPA ) {
conns->c_paddr = NULLPA;
Debug( LDAP_DEBUG_ANY, "conn_init: bad DSA address (%s)\n",
dsa_address ? dsa_address : "NULL", 0, 0 );
} else {
conns->c_paddr = psap_cpy( addr );
}
conns->c_refcnt = 1; /* this conn is never deleted */
conns->c_next = NULL;
return( 0 );
}
void
conn_free( struct conn *conn )
{
struct timeval tv;
Debug( LDAP_DEBUG_TRACE, "conn_free (%s): refcnt is %d\n",
paddr2str( conn->c_paddr, NULLNA ), conn->c_refcnt, 0 );
if ( --conn->c_refcnt > 0 )
return;
gettimeofday( &tv, (struct timezone *)NULL );
if ( conn->c_time != 0L && (tv.tv_sec - conn->c_time)
< referral_connection_timeout ) {
Debug( LDAP_DEBUG_TRACE, "conn_free: referral conn ttl is %d\n",
referral_connection_timeout - (tv.tv_sec - conn->c_time),
0, 0 );
return;
}
conn_del( conn );
if ( conn->c_paddr )
free( (char *) conn->c_paddr );
if ( conn->c_dn )
free( conn->c_dn );
if ( conn->c_credlen > 0 )
free( conn->c_cred );
free( conn );
}
void
conn_del( struct conn *conn )
{
struct conn *tmp, *prev;
Debug( LDAP_DEBUG_TRACE, "conn_del (%s)\n",
paddr2str( conn->c_paddr, NULLNA ), 0, 0 );
prev = NULL;
for ( tmp = conns; tmp != NULL; tmp = tmp->c_next ) {
if ( tmp == conn )
break;
prev = tmp;
}
if ( tmp == NULL ) {
Debug( LDAP_DEBUG_ANY, "conn_del: cannot find conn\n", 0, 0,
0 );
return;
}
if ( prev == NULL ) {
conns = conns->c_next; /* delete head of list */
} else {
prev->c_next = tmp->c_next;
}
}
void
conn_setfds( fd_set *fds )
{
struct conn *tmp;
for ( tmp = conns; tmp != NULL; tmp = tmp->c_next ) {
if ( tmp->c_ad != -1 )
FD_SET( tmp->c_ad, fds );
}
}
void
conn_badfds( void )
{
struct conn *tmp;
for ( tmp = conns; tmp != NULL; tmp = tmp->c_next ) {
if ( isclosed( tmp->c_ad ) ) {
Debug( LDAP_DEBUG_ANY, "conn_badfds: fd %d is bad\n",
tmp->c_ad, 0, 0 );
tmp->c_ad = -1;
}
}
}
struct conn *
conn_getfd( fd_set *fds )
{
struct conn *tmp;
for ( tmp = conns; tmp != NULL; tmp = tmp->c_next ) {
if ( tmp->c_ad != -1 )
if ( FD_ISSET( tmp->c_ad, fds ) )
return( tmp );
}
return( NULL );
}
void
conn_add( struct conn *new )
{
struct timeval tv;
#ifdef LDAP_DEBUG
if ( ldap_debug & LDAP_DEBUG_CONNS ) {
char *str;
str = paddr2str( new->c_paddr, NULLNA );
Debug( LDAP_DEBUG_CONNS, "conn_add: (%s)\n", str, 0, 0 );
}
#endif
gettimeofday( &tv, (struct timezone *)NULL );
new->c_time = tv.tv_sec;
new->c_next = conns;
new->c_refcnt = 1;
conns = new;
}
static int
psap_cmp( struct PSAPaddr *a, struct PSAPaddr *b )
{
return( bcmp( (char *) a, (char *) b, sizeof(struct PSAPaddr) ) );
}
struct conn *
conn_find( struct conn *c )
{
struct conn *tmp;
#ifdef LDAP_DEBUG
if ( ldap_debug & LDAP_DEBUG_CONNS ) {
char *str;
str = paddr2str( c->c_paddr, NULLNA );
Debug( LDAP_DEBUG_CONNS, "conn_find: (%s)\n", str, 0, 0 );
}
#endif
for ( tmp = conns; tmp != NULL; tmp = tmp->c_next ) {
#ifdef LDAP_DEBUG
if ( ldap_debug & LDAP_DEBUG_CONNS ) {
char *str;
str = paddr2str( tmp->c_paddr, NULLNA );
Debug( LDAP_DEBUG_CONNS, "conn_find: compare to (%s)\n",
str, 0, 0 );
}
#endif
if ( psap_cmp( tmp->c_paddr, c->c_paddr ) == 0
&& strcmp( tmp->c_dn, c->c_dn ) == 0
&& tmp->c_credlen == c->c_credlen
&& bcmp( tmp->c_cred, c->c_cred, c->c_credlen ) == 0 ) {
Debug( LDAP_DEBUG_CONNS, "conn_find: found\n", 0,
0, 0 );
return( tmp );
}
}
Debug( LDAP_DEBUG_CONNS, "conn_find: not found\n", 0, 0, 0 );
return( NULL );
}
void
conn_close( void )
{
struct conn *tmp;
for ( tmp = conns; tmp != NULL; tmp = tmp->c_next ) {
if ( tmp->c_ad != -1 )
dap_unbind( tmp->c_ad );
}
}
int
isclosed( int ad )
{
int o;
if ( ioctl( ad, FIOGETOWN, &o ) < 0 )
return( errno == EBADF ? 1 : 0 );
else
return( 0 );
}