X-Git-Url: https://git.distorted.org.uk/~mdw/adns/blobdiff_plain/4353a5c47b202786905257e520fe570a570e67bc..31144a72ed24e2d3cd62f5f1239e219737beeff4:/src/submit.c diff --git a/src/submit.c b/src/submit.c index ea10ab8..bd214b1 100644 --- a/src/submit.c +++ b/src/submit.c @@ -9,18 +9,20 @@ #include "internal.h" static adns_query allocquery(adns_state ads, const char *owner, int ol, - int id, adns_rrtype type, + int id, const typeinfo *typei, adns_queryflags flags, const qcontext *ctx) { /* Query message used is the one assembled in ads->rqbuf */ adns_query qu; - + adns_answer *ans; + qu= malloc(sizeof(*qu)+ol+1+ads->rqbuf.used); if (!qu) return 0; + adns__vbuf_init(&qu->ansbuf); + qu->cname= 0; qu->state= query_udp; qu->next= qu->back= qu->parent= 0; LIST_INIT(qu->children); qu->siblings.next= qu->siblings.back= 0; - qu->type= type; - adns__vbuf_init(&qu->answer); + qu->typei= typei; qu->id= id; qu->flags= flags; qu->udpretries= 0; @@ -32,16 +34,16 @@ static adns_query allocquery(adns_state ads, const char *owner, int ol, qu->querymsg= qu->owner+ol+1; memcpy(qu->owner+ol+1,ads->rqbuf.buf,ads->rqbuf.used); qu->querylen= ads->rqbuf.used; + return qu; } static int failsubmit(adns_state ads, const qcontext *ctx, adns_query *query_r, - adns_rrtype type, adns_queryflags flags, - int id, adns_status stat) { + adns_queryflags flags, int id, adns_status stat) { adns_query qu; ads->rqbuf.used= 0; - qu= allocquery(ads,0,0,id,type,flags,ctx); if (!qu) return errno; + qu= allocquery(ads,0,0,id,0,flags,ctx); if (!qu) return errno; adns__query_fail(ads,qu,stat); *query_r= qu; return 0; @@ -58,21 +60,25 @@ int adns_submit(adns_state ads, int ol, id, r; qcontext ctx; struct timeval now; + const typeinfo *typei; ctx.ext= context; id= ads->nextid++; r= gettimeofday(&now,0); if (r) return errno; + typei= adns__findtype(type); + if (!typei) return failsubmit(ads,context,query_r,flags,id,adns_s_notimplemented); + ol= strlen(owner); - if (ol<=1 || ol>MAXDNAME+1) - return failsubmit(ads,context,query_r,type,flags,id,adns_s_invaliddomain); + if (ol<=1 || ol>DNS_MAXDOMAIN+1) + return failsubmit(ads,context,query_r,flags,id,adns_s_invaliddomain); if (owner[ol-1]=='.' && owner[ol-2]!='\\') { flags &= ~adns_qf_search; ol--; } - stat= adns__mkquery(ads,owner,ol,id,type,flags); - if (stat) return failsubmit(ads,context,query_r,type,flags,id,stat); - - qu= allocquery(ads,owner,ol,id,type,flags,context); if (!qu) return errno; + stat= adns__mkquery(ads,owner,ol,id,typei,flags); + if (stat) return failsubmit(ads,context,query_r,flags,id,stat); + + qu= allocquery(ads,owner,ol,id,typei,flags,&ctx); if (!qu) return errno; adns__query_udp(ads,qu,now); adns__autosys(ads,now); @@ -99,5 +105,5 @@ int adns_synchronous(adns_state ads, } void adns_cancel(adns_state ads, adns_query query) { - abort(); /* FIXME */ + abort(); /* fixme */ }