forked from ravinet/mahimahi
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathremote_proxy_test_client.cc
59 lines (48 loc) · 2.22 KB
/
remote_proxy_test_client.cc
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
/* -*-mode:c++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
#include "socket.hh"
#include "event_loop.hh"
#include "bulk_parser.hh"
#include "http_record.pb.h"
#include "http_header.hh"
#include "int32.hh"
using namespace std;
int main( int argc, char *argv[] )
{
try {
if ( argc != 4 ) {
throw Exception( "Usage", string( argv[ 0 ] ) + " host port url" );
}
Socket server( TCP );
server.connect( Address( argv[ 1 ], argv[ 2 ] ) );
/* parse url into scheme and HTTPMessage request */
string url( argv[ 3 ] );
string scheme = url.substr( 0, url.find( ":" ) );
string hostname = url.substr( url.find( ":" ) + 3 );
/* Construct bulk request */
MahimahiProtobufs::BulkRequest bulk_request;
bulk_request.set_scheme( scheme == "https" ? MahimahiProtobufs::BulkRequest_Scheme_HTTPS : MahimahiProtobufs::BulkRequest_Scheme_HTTP );
MahimahiProtobufs::HTTPMessage request_message;
request_message.set_first_line( "GET / HTTP/1.1" );
HTTPHeader request_header( "Host: " + hostname );
request_message.add_header()->CopyFrom( request_header.toprotobuf() );
bulk_request.mutable_request()->CopyFrom( request_message );
string request_proto;
bulk_request.SerializeToString( &request_proto );
/* Make request string to send (prepended with size) */
string request = static_cast<string>( Integer32( request_proto.size() ) ) + request_proto;
/* For now, write bulk request to a file for offline parsing and write simple HTTP request to server */
server.write( "GET / HTTP/1.1\r\nHost: " + url + "\r\n\r\n" );
FileDescriptor bulkreply = SystemCall( "open", open( "bulk_request.txt", O_WRONLY | O_CREAT, 00700 ) );
bulkreply.write( request );
cout << "Wrote request to file. Request protobuf size: " << Integer32( request_proto.size() ) << endl;
string bulk_response;
BulkParser bulk_parser;
while ( not server.eof() ) {
bulk_response.append( server.read() );
}
bulk_parser.parse( bulk_response );
} catch ( const Exception & e ) {
e.perror();
return EXIT_FAILURE;
}
}