#include #include #include #include #include #include #include #include "mduptab.h" #include "mstorage.h" #include "str.h" #include "ldif.h" #include "byte.h" #include "textcode.h" #include "stralloc.h" mduptab_t attributes,classes; mstorage_t stringtable; long dn, objectClass; unsigned long ldifrecords; static void addattribute(struct ldaprec** l,long name,long val) { if (name==dn) (*l)->dn=val; else if ((*l)->na[(*l)->n].name=name; (*l)->a[(*l)->n].value=val; ++(*l)->n; } else { buffer_putsflush(buffer_2,"LDIF parse error: too many attributes!\n"); exit(1); } } /* "ou=fnord; O=fefe; c=de" -> "ou=fnord,o=fefe,c=de" */ /* returns the length of the new string */ static int normalize_dn(char* dest,const char* src,int len) { int makelower=1; char* orig=dest; while (len) { if (*src==';' || *src==',') { *dest=','; while (len>1 && src[1]==' ') { ++src; --len; } makelower=1; } else { if (makelower) *dest=tolower(*src); else *dest=*src; if (*dest=='=') makelower=0; } ++dest; ++src; --len; } return dest-orig; } static int unbase64(char* buf) { unsigned int destlen; char temp[8192]; long l=scan_base64(buf,temp,&destlen); if (buf[l] && buf[l]!='\n') return 0; byte_copy(buf,destlen,temp); return destlen; } static int parserec(buffer* b, struct ldaprec** l) { char buf[8192]; int n,i,eof=0,ofs=0; unsigned int i2; int len,base64,binary; stralloc payload={0,0,0}; if (!(*l=malloc(sizeof(struct ldaprec)))) return 2; (*l)->dn=-1; (*l)->next=0; (*l)->n=0; ldifrecords=0; do { long tmp, val; base64=binary=0; n=ofs+buffer_get_token(b,buf+ofs,8192-ofs,":",1); if (n==0) break; i=scan_whitenskip(buf,n); buf[n]=0; if ((i2=str_chr(buf,';'))next=m; m->n=0; m->dn=-1; m->next=0; ofs=0; // dumprec(*l); l=&((*l)->next); ++ldifrecords; continue; } else { ofs=1; buf[0]=c; } } // buf[n]=0; #if 1 stralloc_0(&payload); if (base64) { len=unbase64(payload.s); if (!binary) { payload.s[len]=0; ++len; } } else len=n+1; #if 0 buffer_puts(buffer_2,"feld \""); buffer_puts(buffer_2,attributes.strings.root+tmp); buffer_puts(buffer_2,"\", wert \""); buffer_put(buffer_2,payload.s,len); buffer_putsflush(buffer_2,"\".\n"); #endif if (tmp==objectClass) { if ((val=mduptab_add(&classes,payload.s,len-1))<0) goto nomem; } else if (tmp==dn) { char* newdn=alloca(payload.len+1); if ((val=mstorage_add(&stringtable,newdn,normalize_dn(newdn,payload.s,payload.len)))<0) goto nomem; } else if ((val=mstorage_add_bin(&stringtable,payload.s,payload.len))<0) goto nomem; addattribute(l,tmp,val); #endif } while (!eof); if ((*l)->dn<0) { struct ldaprec* m=(*l)->next; free((*l)); (*l)=m; } return 0; } struct ldaprec *first=0; int ldif_parse(const char* filename) { char buf[4096]; int fd=open_read(filename); buffer in; if (fd<0) return 1; buffer_init(&in,read,fd,buf,sizeof buf); dn=mduptab_adds(&attributes,"dn"); objectClass=mduptab_adds(&attributes,"objectClass"); { int res=parserec(&in,&first); close(fd); return res; } }