struct bufferevent *bev;
struct evhttp_connection *evcon;
struct evhttp_request *req;
+ struct evkeyvalq *output_headers;
- if (argc != 2)
+ int i;
+
+ for (i = 1; i < argc; i++) {
+ if (!strcmp("-url", argv[i])) {
+ if (i < argc - 1) {
+ url = argv[i + 1];
+ } else {
+ syntax();
+ }
+ } else if (!strcmp("-ignore-cert", argv[i])) {
+ ignore_cert = 1;
+ } else if (!strcmp("-data", argv[i])) {
+ if (i < argc - 1) {
+ data_file = argv[i + 1];
+ } else {
+ syntax();
+ }
+ } else if (!strcmp("-help", argv[i])) {
+ syntax();
+ }
+ }
+
+ if (!url) {
syntax();
+ }
- url = argv[1];
http_uri = evhttp_uri_parse(url);
if (http_uri == NULL) {
die("malformed url");
return 1;
}
- evhttp_add_header(req->output_headers, "Host", host);
- evhttp_add_header(req->output_headers, "Connection", "close");
+ output_headers = evhttp_request_get_output_headers(req);
+ evhttp_add_header(output_headers, "Host", host);
+ evhttp_add_header(output_headers, "Connection", "close");
- r = evhttp_make_request(evcon, req, EVHTTP_REQ_GET, uri);
+ if (data_file) {
+ FILE * f = fopen(data_file, "rb");
+ char buf[1024];
+ ssize_t s;
+ size_t bytes = 0;
+
+ if (!f) {
+ syntax();
+ }
+
+ while ((s = fread(buf, 1, sizeof(buf), f)) > 0) {
+ evbuffer_add(req->output_buffer, buf, s);
+ bytes += s;
+ }
+ snprintf(buf, sizeof(buf)-1, "%lu", bytes);
+ evhttp_add_header(req->output_headers, "Content-Length", buf);
+ fclose(f);
+ }
+
+ r = evhttp_make_request(evcon, req, data_file ? EVHTTP_REQ_POST : EVHTTP_REQ_GET, uri);
if (r != 0) {
fprintf(stderr, "evhttp_make_request() failed\n");
return 1;