Files
whatcd-Ocelot/site_comm.cpp
2014-09-02 23:14:39 +02:00

124 lines
3.2 KiB
C++

#include <iostream>
#include <istream>
#include <ostream>
#include <string>
#include <sstream>
#include <queue>
#include <mutex>
#include <boost/asio.hpp>
#include <thread>
#include "config.h"
#include "site_comm.h"
using boost::asio::ip::tcp;
site_comm::site_comm(config &config)
{
conf = config;
t_active = false;
}
bool site_comm::all_clear() {
return (token_queue.size() == 0);
}
void site_comm::expire_token(int torrent, int user)
{
std::stringstream token_pair;
token_pair << user << ':' << torrent;
if (expire_token_buffer != "") {
expire_token_buffer += ",";
}
expire_token_buffer += token_pair.str();
if (expire_token_buffer.length() > 350) {
std::cout << "Flushing overloaded token buffer" << std::endl;
std::unique_lock<std::mutex> lock(expire_queue_lock);
token_queue.push(expire_token_buffer);
expire_token_buffer.clear();
}
}
void site_comm::flush_tokens()
{
std::unique_lock<std::mutex> lock(expire_queue_lock);
size_t qsize = token_queue.size();
if (verbose_flush || qsize > 0) {
std::cout << "Token expire queue size: " << qsize << std::endl;
}
if (expire_token_buffer == "") {
return;
}
token_queue.push(expire_token_buffer);
expire_token_buffer.clear();
if (t_active == false) {
std::thread thread(&site_comm::do_flush_tokens, this);
thread.detach();
}
}
void site_comm::do_flush_tokens()
{
t_active = true;
try {
while (token_queue.size() > 0) {
boost::asio::io_service io_service;
tcp::resolver resolver(io_service);
tcp::resolver::query query(conf.site_host, "http");
tcp::resolver::iterator endpoint_iterator = resolver.resolve(query);
tcp::resolver::iterator end;
tcp::socket socket(io_service);
boost::system::error_code error = boost::asio::error::host_not_found;
while (error && endpoint_iterator != end) {
socket.close();
socket.connect(*endpoint_iterator++, error);
}
if (error) {
throw boost::system::system_error(error);
}
boost::asio::streambuf request;
std::ostream request_stream(&request);
request_stream << "GET " << conf.site_path << "/tools.php?key=" << conf.site_password;
request_stream << "&type=expiretoken&action=ocelot&tokens=" << token_queue.front() << " HTTP/1.0\r\n";
request_stream << "Host: " << conf.site_host << "\r\n";
request_stream << "Accept: */*\r\n";
request_stream << "Connection: close\r\n\r\n";
boost::asio::write(socket, request);
boost::asio::streambuf response;
boost::asio::read_until(socket, response, "\r\n");
std::istream response_stream(&response);
std::string http_version;
response_stream >> http_version;
unsigned int status_code;
response_stream >> status_code;
std::string status_message;
std::getline(response_stream, status_message);
if (!response_stream || http_version.substr(0, 5) != "HTTP/") {
std::cout << "Invalid response" << std::endl;
continue;
}
if (status_code == 200) {
std::unique_lock<std::mutex> lock(expire_queue_lock);
token_queue.pop();
} else {
std::cout << "Response returned with status code " << status_code << " when trying to expire a token!" << std::endl;;
}
}
} catch (std::exception &e) {
std::cout << "Exception: " << e.what() << std::endl;
}
t_active = false;
}
site_comm::~site_comm()
{
}