axmol/core/network/HttpRequest.h

273 lines
8.3 KiB
C
Raw Normal View History

2019-11-23 20:27:39 +08:00
/****************************************************************************
Copyright (c) 2010-2012 cocos2d-x.org
Copyright (c) 2013-2016 Chukong Technologies Inc.
Copyright (c) 2017-2018 Xiamen Yaji Software Co., Ltd.
Copyright (c) 2019-present Axmol Engine contributors (see AUTHORS.md).
2019-11-23 20:27:39 +08:00
https://axmol.dev/
2019-11-23 20:27:39 +08:00
Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in
all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
THE SOFTWARE.
****************************************************************************/
#ifndef __HTTP_REQUEST_H__
#define __HTTP_REQUEST_H__
#include <string>
#include <vector>
#include <memory>
#include <future>
#include "base/Object.h"
#include "base/Macros.h"
2019-11-23 20:27:39 +08:00
#include "yasio/byte_buffer.hpp"
2019-11-23 20:27:39 +08:00
/**
* @addtogroup network
* @{
*/
NS_AX_BEGIN
2019-11-23 20:27:39 +08:00
2021-12-25 10:04:45 +08:00
namespace network
{
2019-11-23 20:27:39 +08:00
class HttpClient;
class HttpResponse;
typedef std::function<void(HttpClient* client, HttpResponse* response)> ccHttpRequestCallback;
/**
* Defines the object which users must packed for HttpClient::send(HttpRequest*) method.
* Please refer to tests/test-cpp/Classes/ExtensionTest/NetworkTest/HttpClientTest.cpp as a sample
* @since v2.0.2
*
* @lua NA
*/
class AX_DLL HttpRequest : public Object
2019-11-23 20:27:39 +08:00
{
friend class HttpClient;
2021-12-25 10:04:45 +08:00
2019-11-23 20:27:39 +08:00
public:
static const int MAX_REDIRECT_COUNT = 3;
2019-11-23 20:27:39 +08:00
/**
* The HttpRequest type enum used in the HttpRequest::setRequestType.
*/
enum class Type
{
GET,
PATCH,
2019-11-23 20:27:39 +08:00
POST,
PUT,
DELETE,
UNKNOWN,
};
/**
* Constructor.
* Because HttpRequest object will be used between UI thread and network thread,
requestObj->autorelease() is forbidden to avoid crashes in AutoreleasePool
new/retain/release still works, which means you need to release it manually
Please refer to HttpRequestTest.cpp to find its usage.
*/
2021-12-25 10:04:45 +08:00
HttpRequest() : _requestType(Type::UNKNOWN), _pCallback(nullptr), _pUserData(nullptr) {}
2019-11-23 20:27:39 +08:00
/** Destructor. */
2021-12-25 10:04:45 +08:00
virtual ~HttpRequest() {}
2019-11-23 20:27:39 +08:00
/**
* Override autorelease method to avoid developers to call it.
* If this function was called, it would trigger assert in debug mode
*
* @return Object* always return nullptr.
2019-11-23 20:27:39 +08:00
*/
Object* autorelease()
2019-11-23 20:27:39 +08:00
{
2022-07-16 10:43:05 +08:00
AXASSERT(false,
2021-12-25 10:04:45 +08:00
"HttpResponse is used between network thread and ui thread \
2019-11-23 20:27:39 +08:00
therefore, autorelease is forbidden here");
return nullptr;
}
// setter/getters for properties
/**
* Set request type of HttpRequest object before being sent,now it support the enum value of HttpRequest::Type.
*
* @param type the request type.
*/
2021-12-25 10:04:45 +08:00
void setRequestType(Type type) { _requestType = type; }
2019-11-23 20:27:39 +08:00
/**
* Get the request type of HttpRequest object.
*
* @return HttpRequest::Type.
*/
2021-12-25 10:04:45 +08:00
Type getRequestType() const { return _requestType; }
2019-11-23 20:27:39 +08:00
/**
* Set the url address of HttpRequest object.
* The url value could be like these: "http://httpbin.org/ip" or "https://httpbin.org/get"
*
* @param url the string object.
*/
void setUrl(std::string_view url) { _url = url; }
2019-11-23 20:27:39 +08:00
/**
* Get the url address of HttpRequest object.
*
* @return const char* the pointer of _url.
*/
std::string_view getUrl() const { return _url; }
2019-11-23 20:27:39 +08:00
/**
* Set the request data of HttpRequest object.
*
* @param buffer the buffer of request data, it support binary data.
* @param len the size of request data.
*/
2021-12-25 10:04:45 +08:00
void setRequestData(const char* buffer, size_t len) { _requestData.assign(buffer, buffer + len); }
2019-11-23 20:27:39 +08:00
/**
* Get the request data pointer of HttpRequest object.
*
* @return char* the request data pointer.
*/
char* getRequestData()
{
2021-12-25 10:04:45 +08:00
if (!_requestData.empty())
2019-11-23 20:27:39 +08:00
return _requestData.data();
return nullptr;
}
/**
* Get the size of request data
*
* @return ssize_t the size of request data
*/
2021-12-25 10:04:45 +08:00
ssize_t getRequestDataSize() const { return _requestData.size(); }
2019-11-23 20:27:39 +08:00
/**
* Set a string tag to identify your request.
* This tag can be found in HttpResponse->getHttpRequest->getTag().
*
* @param tag the string object.
*/
void setTag(std::string_view tag) { _tag = tag; }
2019-11-23 20:27:39 +08:00
/**
* Get the string tag to identify the request.
* The best practice is to use it in your MyClass::onMyHttpRequestCompleted(sender, HttpResponse*) callback.
*
* @return const char* the pointer of _tag
*/
std::string_view getTag() const { return _tag; }
2019-11-23 20:27:39 +08:00
/**
* Set user-customed data of HttpRequest object.
* You can attach a customed data in each request, and get it back in response callback.
* But you need to new/delete the data pointer manually.
*
* @param pUserData the string pointer
*/
2021-12-25 10:04:45 +08:00
void setUserData(void* pUserData) { _pUserData = pUserData; }
2019-11-23 20:27:39 +08:00
/**
* Get the user-customed data pointer which were pre-setted.
* Don't forget to delete it. HttpClient/HttpResponse/HttpRequest will do nothing with this pointer.
*
* @return void* the pointer of user-customed data.
*/
2021-12-25 10:04:45 +08:00
void* getUserData() const { return _pUserData; }
2019-11-23 20:27:39 +08:00
/**
* Set response callback function of HttpRequest object.
* When response come back, we would call _pCallback to process response data.
*
* @param callback the ccHttpRequestCallback function.
*/
2021-12-25 10:04:45 +08:00
void setResponseCallback(const ccHttpRequestCallback& callback) { _pCallback = callback; }
2019-11-23 20:27:39 +08:00
/**
* Get ccHttpRequestCallback callback function.
*
* @return const ccHttpRequestCallback& ccHttpRequestCallback callback function.
*/
2021-12-25 10:04:45 +08:00
const ccHttpRequestCallback& getCallback() const { return _pCallback; }
2019-11-23 20:27:39 +08:00
/**
* Set custom-defined headers.
*
* @param headers The string vector of custom-defined headers.
*/
2021-12-25 10:04:45 +08:00
void setHeaders(const std::vector<std::string>& headers) { _headers = headers; }
2019-11-23 20:27:39 +08:00
/**
* Get custom headers.
*
* @return std::vector<std::string> the string vector of custom-defined headers.
*/
2021-12-25 10:04:45 +08:00
const std::vector<std::string>& getHeaders() const { return _headers; }
2019-11-23 20:27:39 +08:00
void setHosts(std::vector<std::string> hosts) { _hosts = std::move(hosts); }
const std::vector<std::string>& getHosts() const { return _hosts; }
2019-11-23 20:27:39 +08:00
private:
2021-12-25 10:04:45 +08:00
void setSync(bool sync)
{
if (sync)
_syncState = std::make_shared<std::promise<HttpResponse*>>();
else
_syncState.reset();
}
2021-12-25 10:04:45 +08:00
std::shared_ptr<std::promise<HttpResponse*>> getSyncState() { return _syncState; }
2021-12-25 10:04:45 +08:00
HttpResponse* wait()
{
if (_syncState)
return _syncState->get_future().get();
return nullptr;
}
2019-11-23 20:27:39 +08:00
protected:
// properties
2021-12-25 10:04:45 +08:00
Type _requestType; /// kHttpRequestGet, kHttpRequestPost or other enums
std::string _url; /// target url that this request is sent to
yasio::sbyte_buffer _requestData; /// used for POST
std::string _tag; /// user defined tag, to identify different requests in response callback
ccHttpRequestCallback _pCallback; /// C++11 style callbacks
void* _pUserData; /// You can add your customed data here
std::vector<std::string> _headers; /// custom http headers
std::vector<std::string> _hosts;
std::shared_ptr<std::promise<HttpResponse*>> _syncState;
2019-11-23 20:27:39 +08:00
};
2021-12-25 10:04:45 +08:00
} // namespace network
2019-11-23 20:27:39 +08:00
NS_AX_END
2019-11-23 20:27:39 +08:00
// end group
/// @}
2021-12-25 10:04:45 +08:00
#endif //__HTTP_REQUEST_H__