cleans up http headers, incorporate review feedback

This commit is contained in:
Joe Bryan 2018-04-10 16:21:42 -07:00
parent 05339a771e
commit a62d59edf0
2 changed files with 33 additions and 43 deletions

View File

@ -1,4 +1,4 @@
/* v/http.c /* v/cttp.c
** **
*/ */
#include <stdio.h> #include <stdio.h>
@ -7,23 +7,16 @@
#include <sys/ioctl.h> #include <sys/ioctl.h>
#include <sys/stat.h> #include <sys/stat.h>
#include <unistd.h> #include <unistd.h>
#include <setjmp.h>
#include <gmp.h>
#include <stdint.h> #include <stdint.h>
#include <sys/socket.h> #include <sys/socket.h>
#include <netinet/in.h> #include <netinet/in.h>
#include <uv.h> #include <uv.h>
#include <errno.h> #include <errno.h>
#include <curses.h>
#include <termios.h>
#include <term.h>
#include <openssl/ssl.h> #include <openssl/ssl.h>
#include <h2o.h>
#include "all.h" #include "all.h"
#include "vere/vere.h" #include "vere/vere.h"
#include "h2o.h"
// XX deduplicate with _http_vec_to_atom // XX deduplicate with _http_vec_to_atom
/* _cttp_vec_to_atom(): convert h2o_iovec_t to atom (cord) /* _cttp_vec_to_atom(): convert h2o_iovec_t to atom (cord)
@ -644,7 +637,6 @@ _cttp_creq_fire(u3_creq* ceq_u)
free(hos_c); free(hos_c);
} }
_cttp_creq_fire_str(ceq_u, "User-Agent: urbit/vere-" URBIT_VERSION "\r\n");
_cttp_creq_fire_heds(ceq_u, ceq_u->hed_u); _cttp_creq_fire_heds(ceq_u, ceq_u->hed_u);
if ( !ceq_u->bod_u ) { if ( !ceq_u->bod_u ) {
@ -733,7 +725,8 @@ _cttp_creq_on_body(h2o_http1client_t* cli_u, const c3_c* err_c)
h2o_buffer_t* buf_u = cli_u->sock->input; h2o_buffer_t* buf_u = cli_u->sock->input;
if ( buf_u->size ) { if ( buf_u->size ) {
_cttp_cres_fire_body(ceq_u->res_u, _cttp_bod_new(buf_u->size, buf_u->bytes)); _cttp_cres_fire_body(ceq_u->res_u,
_cttp_bod_new(buf_u->size, buf_u->bytes));
h2o_buffer_consume(&cli_u->sock->input, buf_u->size); h2o_buffer_consume(&cli_u->sock->input, buf_u->size);
} }

View File

@ -12,14 +12,11 @@
#include <netinet/in.h> #include <netinet/in.h>
#include <uv.h> #include <uv.h>
#include <errno.h> #include <errno.h>
#include <openssl/ssl.h>
#include <h2o.h>
#include "all.h" #include "all.h"
#include "vere/vere.h" #include "vere/vere.h"
#include "h2o.h"
#include <openssl/ssl.h>
static const c3_i TCP_BACKLOG = 16; static const c3_i TCP_BACKLOG = 16;
/* _http_vec_to_meth(): convert h2o_iovec_t to meth /* _http_vec_to_meth(): convert h2o_iovec_t to meth
@ -45,7 +42,6 @@ _http_vec_to_meth(h2o_iovec_t vec_u)
static u3_noun static u3_noun
_http_vec_to_atom(h2o_iovec_t vec_u) _http_vec_to_atom(h2o_iovec_t vec_u)
{ {
// XX portable?
return u3i_bytes(vec_u.len, (const c3_y*)vec_u.base); return u3i_bytes(vec_u.len, (const c3_y*)vec_u.base);
} }
@ -105,7 +101,21 @@ _http_heds_to_noun(h2o_header_t* hed_u, c3_d hed_d)
return hed; return hed;
} }
// XX allocating hed_u and members at once causes SIGSEGV. WTF? /* _http_heds_free(): free header linked list
*/
static void
_http_heds_free(u3_hhed* hed_u)
{
while ( hed_u ) {
u3_hhed* nex_u = hed_u->nex_u;
free(hed_u->nam_c);
free(hed_u->val_c);
free(hed_u);
hed_u = nex_u;
}
}
/* _http_hed_new(): create u3_hhed from nam/val cords /* _http_hed_new(): create u3_hhed from nam/val cords
*/ */
static u3_hhed* static u3_hhed*
@ -150,21 +160,6 @@ _http_heds_from_noun(u3_noun hed)
return hed_u; return hed_u;
} }
/* _http_heds_free(): free header linked list
*/
static void
_http_heds_free(u3_hhed* hed_u)
{
while ( hed_u ) {
u3_hhed* nex_u = hed_u->nex_u;
free(hed_u->nam_c);
free(hed_u->val_c);
free(hed_u);
hed_u = nex_u;
}
}
/* _http_req_find(): find http request in connection by sequence. /* _http_req_find(): find http request in connection by sequence.
*/ */
static u3_hreq* static u3_hreq*
@ -282,11 +277,11 @@ _http_req_respond(u3_hreq* req_u, u3_noun sas, u3_noun hed, u3_noun bod)
h2o_req_t* rec_u = req_u->rec_u; h2o_req_t* rec_u = req_u->rec_u;
rec_u->res.status = sas; rec_u->res.status = sas;
rec_u->res.reason = (sas < 200) ? "Weird" : rec_u->res.reason = (sas < 200) ? "weird" :
(sas < 300) ? "OK" : (sas < 300) ? "ok" :
(sas < 400) ? "Moved" : (sas < 400) ? "moved" :
(sas < 500) ? "Missing" : (sas < 500) ? "missing" :
"Hosed"; "hosed";
u3_hhed* hed_u = _http_heds_from_noun(u3k(hed)); u3_hhed* hed_u = _http_heds_from_noun(u3k(hed));
u3_hhed* deh_u = hed_u; u3_hhed* deh_u = hed_u;
@ -372,7 +367,7 @@ _http_rec_accept(h2o_handler_t* han_u, h2o_req_t* rec_u)
uL(fprintf(uH, "strange %.*s request\n", (int)rec_u->method.len, uL(fprintf(uH, "strange %.*s request\n", (int)rec_u->method.len,
rec_u->method.base)); rec_u->method.base));
} }
_http_rec_fail(rec_u, 400, "Bad Request"); _http_rec_fail(rec_u, 400, "bad request");
} }
else { else {
// XX HTTP2 wat do? // XX HTTP2 wat do?
@ -558,7 +553,8 @@ _http_serv_init_h2o(u3_http* htp_u)
{ {
htp_u->fig_u = c3_calloc(sizeof(*htp_u->fig_u)); htp_u->fig_u = c3_calloc(sizeof(*htp_u->fig_u));
h2o_config_init(htp_u->fig_u); h2o_config_init(htp_u->fig_u);
htp_u->fig_u->server_name = h2o_iovec_init(H2O_STRLIT("urbit/vere-" URBIT_VERSION)); htp_u->fig_u->server_name = h2o_iovec_init(
H2O_STRLIT("urbit/vere-" URBIT_VERSION));
// XX use u3_Host.ops_u.nam_c? Or ship.urbit.org? Multiple hosts? // XX use u3_Host.ops_u.nam_c? Or ship.urbit.org? Multiple hosts?
// see https://github.com/urbit/urbit/issues/914 // see https://github.com/urbit/urbit/issues/914
@ -575,7 +571,8 @@ _http_serv_init_h2o(u3_http* htp_u)
htp_u->cep_u->ssl_ctx = u3_Host.tls_u; htp_u->cep_u->ssl_ctx = u3_Host.tls_u;
} }
htp_u->han_u = h2o_create_handler(&htp_u->hos_u->fallback_path, sizeof(*htp_u->han_u)); htp_u->han_u = h2o_create_handler(&htp_u->hos_u->fallback_path,
sizeof(*htp_u->han_u));
htp_u->han_u->on_req = _http_rec_accept; htp_u->han_u->on_req = _http_rec_accept;
h2o_context_init(htp_u->ctx_u, u3L, htp_u->fig_u); h2o_context_init(htp_u->ctx_u, u3L, htp_u->fig_u);
@ -726,7 +723,6 @@ _http_release_ports_file(c3_c *pax_c)
u3a_free(paf_c); u3a_free(paf_c);
} }
// XX rename (is a card an effect?)
/* u3_http_ef_bake(): notify %eyre that we're live /* u3_http_ef_bake(): notify %eyre that we're live
*/ */
void void
@ -762,7 +758,8 @@ u3_http_ef_thou(c3_l sev_l,
} }
else if ( !(req_u = _http_req_find(hon_u, seq_l)) ) { else if ( !(req_u = _http_req_find(hon_u, seq_l)) ) {
if ( bug_w ) { if ( bug_w ) {
uL(fprintf(uH, "http: request not found: %x/%d/%d\r\n", sev_l, coq_l, seq_l)); uL(fprintf(uH, "http: request not found: %x/%d/%d\r\n",
sev_l, coq_l, seq_l));
} }
} }
else { else {