summaryrefslogtreecommitdiff
path: root/protocols/Omegle/src/client.h
blob: be5ec9055c136299afff5d036f9f517ddcde40fc (plain)
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
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
/*

Omegle plugin for Miranda Instant Messenger
_____________________________________________

Copyright © 2011-12 Robert Pösel

This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 2 of the License, or
(at your option) any later version.

This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
GNU General Public License for more details.

You should have received a copy of the GNU General Public License
along with this program.  If not, see <http://www.gnu.org/licenses/>.

*/

#pragma once

#define FORCE_DISCONNECT true

#define STATE_INACTIVE			0	// not connected to any stranger
#define STATE_WAITING			1	// connecting to stranger
#define STATE_ACTIVE			2	// active discussion
#define STATE_DISCONNECTING		3	// disconnecting from stranger
#define STATE_SPY				4	// spy mode (read-only)

class Omegle_client
{
public:

	// Client definition
	Omegle_client( )
	{
		chat_id_ = server_ = question_ = "";
		nick_ = NULL;
		//msgid_ = 0;
		send_message_lock_ = NULL;
		state_ = STATE_INACTIVE;

		old_typing_ = typing_ = spy_mode_ = false;

		hConnection = NULL;
		hEventsConnection = NULL;
		connection_lock_ = NULL;
	}

	HANDLE hConnection;
	HANDLE hEventsConnection;
	HANDLE connection_lock_;

	// Parent handle
	OmegleProto*  parent;

	// Chat data
	std::string chat_id_;
	std::string server_;
	std::string question_;
	TCHAR *nick_;

	HANDLE send_message_lock_;
	//int	msgid_;
	
	// State of client
	int state_;
	bool typing_;
	bool old_typing_;
	bool spy_mode_;

	// Data storage
	std::map< std::string, std::string >    headers;
	void    store_headers( http::response* resp, NETLIBHTTPHEADER* headers, int headers_count );
	
	std::string get_server( bool not_last = false );

	// Connection handling
	unsigned int error_count_;

	bool    handle_entry( std::string method );
	bool    handle_success( std::string method );
	bool    handle_error( std::string method, bool force_disconnect = false );

	void __inline increment_error( ) { error_count_++; }
	void __inline decrement_error( ) { if ( error_count_ > 0 ) error_count_--; }
	void __inline reset_error( ) { error_count_ = 0; }	

	bool    start( );
	bool    stop( );
	bool    events( );

	bool    typing_start( );
	bool    typing_stop( );
	bool    recaptcha( );

	std::string get_page( int );
	
	bool    send_message( std::string message_text );

	// HTTP communication
	http::response  flap( const int request_type, std::string* request_data = NULL, std::string* get_data = NULL );

	int     choose_method( int );
	std::string choose_proto( int );
	std::string choose_server( int, std::string* data = NULL, std::string* get_data = NULL );
	std::string choose_action( int, std::string* data = NULL, std::string* get_data = NULL );
	std::string choose_request_url( int, std::string* data = NULL, std::string* get_data = NULL );

	NETLIBHTTPHEADER*   get_request_headers( int request_type, int* headers_count );

	// Netlib handle

	HANDLE handle_;

	void set_handle(HANDLE h)
	{
		handle_ = h;
	}
};