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
|
#ifndef _HTTP_REQUEST_H_
#define _HTTP_REQUEST_H_
#include "common.h"
enum HTTP_STATUS
{
HTTP_STATUS_OK = 200,
HTTP_STATUS_BAD_REQUEST = 400,
HTTP_STATUS_UNAUTHORIZED = 401,
HTTP_STATUS_FORBIDDEN = 403,
HTTP_STATUS_NOT_FOUND = 404,
HTTP_STATUS_METHOD_NOT_ALLOWED = 405,
HTTP_STATUS_TOO_MANY_REQUESTS = 429,
HTTP_STATUS_SERVICE_UNAVAILABLE = 503,
HTTP_STATUS_INSUFICIENTE_STORAGE = 507
};
class HttpRequest : public NETLIBHTTPREQUEST, public MZeroedObject
{
public:
HttpRequest(HANDLE hNetlibUser, int requestType, LPCSTR url)
{
cbSize = sizeof(NETLIBHTTPREQUEST);
flags = NLHRF_HTTP11;
this->requestType = requestType;
m_hNetlibUser = hNetlibUser;
m_szUrl = mir_strdup(url);
}
~HttpRequest()
{
for (int i = 0; i < headersCount; i++)
{
mir_free(headers[i].szName);
mir_free(headers[i].szValue);
}
mir_free(headers);
mir_free(pData);
}
void AddHeader(LPCSTR szName, LPCSTR szValue)
{
headers = (NETLIBHTTPHEADER*)mir_realloc(headers, sizeof(NETLIBHTTPHEADER)*(headersCount + 1));
headers[headersCount].szName = mir_strdup(szName);
headers[headersCount].szValue = mir_strdup(szValue);
headersCount++;
}
void AddBasicAuthHeader(LPCSTR szLogin, LPCSTR szPassword)
{
char cPair[128];
mir_snprintf(
cPair,
SIZEOF(cPair),
"%s:%s",
szLogin,
szPassword);
char *ePair = (char *)mir_base64_encode((BYTE*)cPair, (UINT)strlen(cPair));
char value[128];
mir_snprintf(
value,
SIZEOF(value),
"Basic %s",
ePair);
mir_free(ePair);
headers = (NETLIBHTTPHEADER*)mir_realloc(headers, sizeof(NETLIBHTTPHEADER)*(headersCount + 1));
headers[headersCount].szName = mir_strdup("Authorization");
headers[headersCount].szValue = mir_strdup(value);
headersCount++;
}
void AddBearerAuthHeader(LPCSTR szValue)
{
char value[128];
mir_snprintf(
value,
SIZEOF(value),
"Bearer %s",
szValue);
headers = (NETLIBHTTPHEADER*)mir_realloc(headers, sizeof(NETLIBHTTPHEADER)*(headersCount + 1));
headers[headersCount].szName = mir_strdup("Authorization");
headers[headersCount].szValue = mir_strdup(value);
headersCount++;
}
/*void AddParameter(LPCSTR szName, LPCSTR szValue)
{
if (m_szUrl.Find('?') == -1)
m_szUrl.AppendFormat("?%s=%s", szName, szValue);
else
m_szUrl.AppendFormat("&%s=%s", szName, szValue);
}
void AddParameter(LPCSTR szName, int value)
{
if (m_szUrl.Find('?') == -1)
m_szUrl.AppendFormat("?%s=%i", szName, value);
else
m_szUrl.AppendFormat("&%s=%i", szName, value);
}*/
NETLIBHTTPREQUEST *Send()
{
szUrl = m_szUrl.GetBuffer();
/*CMStringA message; message.AppendFormat("Send request to %s", szUrl);
CallService(MS_NETLIB_LOG, (WPARAM)m_hNetlibUser, (LPARAM)message.GetBuffer());*/
return (NETLIBHTTPREQUEST*)CallService(MS_NETLIB_HTTPTRANSACTION, (WPARAM)m_hNetlibUser, (LPARAM)this);
}
private:
CMStringA m_szUrl;
HANDLE m_hNetlibUser;
};
#endif //_HTTP_REQUEST_H_
|