|
1 | 1 | use std::{
|
2 |
| - fmt::format, |
3 | 2 | io::{Read, Write},
|
4 |
| - net::TcpListener, |
| 3 | + net::TcpStream, |
| 4 | + str, |
5 | 5 | };
|
6 | 6 |
|
7 |
| -use std::net::{SocketAddr, ToSocketAddrs}; |
| 7 | +use crate::{find_subsequence, HTTPMessage}; |
8 | 8 |
|
9 |
| -use std::str; |
| 9 | +static BUFFER_SIZE: usize = 409600; |
10 | 10 |
|
11 |
| -use crate::{find_subsequence, HTTPMessage}; |
| 11 | +pub fn head(address: &str, path: &str) -> HTTPMessage { |
| 12 | + let mut stream = TcpStream::connect(address).expect("Unable to connect to server"); |
| 13 | + let (host, _) = address.split_once(":").unwrap(); |
| 14 | + let request = format!( |
| 15 | + "HEAD {} HTTP/1.1\r\nHost: {}\r\nAccept: */*\r\n\r\n", |
| 16 | + path, host |
| 17 | + ); |
| 18 | + stream.write(request.as_bytes()).unwrap(); |
| 19 | + let mut buffer: Vec<u8> = vec![0; 1024]; |
| 20 | + stream.read(&mut buffer).unwrap(); |
12 | 21 |
|
13 |
| -pub fn download_part( |
14 |
| - address: &str, |
15 |
| - path: &str, |
16 |
| - bytes_from: usize, |
17 |
| - bytes_to: usize, |
18 |
| -) -> Option<Vec<u8>> { |
19 |
| - let addr = address.to_socket_addrs().unwrap().next().unwrap(); |
20 |
| - println!("{:?}", addr); |
21 |
| - let listener = TcpListener::bind(addr).unwrap(); |
| 22 | + HTTPMessage::new(str::from_utf8(&buffer).unwrap()) |
| 23 | +} |
| 24 | + |
| 25 | +pub fn download_part(address: String, path: String, bytes_from: usize, bytes_to: usize) -> Vec<u8> { |
| 26 | + let mut stream = TcpStream::connect(&address).expect("Unable to connect to server"); |
22 | 27 | let (host, _) = address.split_once(":").unwrap();
|
23 |
| - for stream in listener.incoming() { |
24 |
| - match stream { |
25 |
| - Ok(mut stream) => { |
26 |
| - let request = format!( |
27 |
| - "GET {} HTTP/1.1\r\nHost: {}\r\nRange: bytes={}-{}\r\nAccept: */*\r\n\r\n", |
28 |
| - path, host, bytes_from, bytes_to |
29 |
| - ); |
30 |
| - stream.write(request.as_bytes()); |
31 |
| - |
32 |
| - let body_size = bytes_to - bytes_from + 1; |
33 |
| - let mut buffer: Vec<u8> = Vec::with_capacity(body_size + 1024); |
34 |
| - let body_break: Vec<u8> = vec![13, 10]; |
35 |
| - stream.read_to_end(&mut buffer).unwrap(); |
36 |
| - |
37 |
| - let loc_body_break = find_subsequence(&buffer, &body_break).unwrap(); |
38 |
| - let metadata = str::from_utf8(&buffer[0..loc_body_break + 2]).unwrap(); |
39 |
| - let message = HTTPMessage::new(metadata); |
40 |
| - println!("{:?}", message); |
41 |
| - } |
42 |
| - Err(e) => { |
43 |
| - eprintln!("Failed to get stream from Tcp Listener : {}", e); |
44 |
| - } |
| 28 | + let request = format!( |
| 29 | + "GET {} HTTP/1.1\r\nHost: {}\r\nRange: bytes={}-{}\r\nAccept: */*\r\n\r\n", |
| 30 | + path, host, bytes_from, bytes_to |
| 31 | + ); |
| 32 | + stream.write(request.as_bytes()).unwrap(); |
| 33 | + |
| 34 | + let body_size = bytes_to - bytes_from + 1; |
| 35 | + let mut buffer: Vec<u8> = vec![0; BUFFER_SIZE]; |
| 36 | + let mut body: Vec<u8> = Vec::with_capacity(body_size); |
| 37 | + let body_break: Vec<u8> = "\r\n\r\n".as_bytes().to_vec(); |
| 38 | + let mut content_consumed: usize = 0; |
| 39 | + |
| 40 | + let mut first = true; |
| 41 | + |
| 42 | + while content_consumed < body_size { |
| 43 | + let bytes_read = stream.read(&mut buffer).unwrap(); |
| 44 | + println!("Read {} bytes", bytes_read); |
| 45 | + |
| 46 | + if bytes_read == 0 { |
| 47 | + panic!("WTF"); |
45 | 48 | }
|
46 | 49 |
|
47 |
| - return None; |
| 50 | + if first { |
| 51 | + first = false; |
| 52 | + let loc_body_break = find_subsequence(&buffer, &body_break).unwrap(); |
| 53 | + let metadata = str::from_utf8(&buffer[0..loc_body_break + 4]).unwrap(); |
| 54 | + let message = HTTPMessage::new(metadata); |
| 55 | + let _content_length: usize = |
| 56 | + str::parse(message.headers.get("Content-Length").unwrap()).unwrap(); |
| 57 | + let content = &buffer[loc_body_break + 4..bytes_read]; |
| 58 | + content_consumed += content.len(); |
| 59 | + body.extend_from_slice(content); |
| 60 | + } else { |
| 61 | + content_consumed += bytes_read; |
| 62 | + body.extend_from_slice(&buffer[0..bytes_read]); |
| 63 | + } |
| 64 | + |
| 65 | + println!("Consumed {} bytes of total {}", content_consumed, body_size); |
48 | 66 | }
|
49 | 67 |
|
50 |
| - unimplemented!() |
| 68 | + assert_eq!(body.len(), body_size); |
| 69 | + |
| 70 | + return body; |
51 | 71 | }
|
0 commit comments