2012-08-07 18:28:07 +08:00
|
|
|
/****************************************************************************
|
|
|
|
Copyright (c) 2010-2012 cocos2d-x.org
|
2014-01-07 11:47:11 +08:00
|
|
|
Copyright (c) 2013-2014 Chukong Technologies Inc.
|
2012-08-07 18:28:07 +08:00
|
|
|
|
|
|
|
http://www.cocos2d-x.org
|
|
|
|
|
|
|
|
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__
|
|
|
|
|
2014-02-20 10:53:49 +08:00
|
|
|
#include <string>
|
|
|
|
#include <vector>
|
2014-04-27 01:11:22 +08:00
|
|
|
#include "base/CCRef.h"
|
|
|
|
#include "2d/ccMacros.h"
|
2012-08-07 18:28:07 +08:00
|
|
|
|
2014-01-02 16:25:35 +08:00
|
|
|
NS_CC_BEGIN
|
|
|
|
|
2013-10-15 18:00:03 +08:00
|
|
|
namespace network {
|
2012-08-07 18:28:07 +08:00
|
|
|
|
2013-06-20 14:15:53 +08:00
|
|
|
class HttpClient;
|
|
|
|
class HttpResponse;
|
2014-02-20 10:53:49 +08:00
|
|
|
|
2014-04-13 05:06:04 +08:00
|
|
|
typedef std::function<void(HttpClient* client, HttpResponse* response)> ccHttpRequestCallback;
|
2014-02-20 10:53:49 +08:00
|
|
|
typedef void (cocos2d::Ref::*SEL_HttpResponse)(HttpClient* client, HttpResponse* response);
|
2014-01-02 21:53:18 +08:00
|
|
|
#define httpresponse_selector(_SELECTOR) (cocos2d::network::SEL_HttpResponse)(&_SELECTOR)
|
2013-04-26 11:42:50 +08:00
|
|
|
|
2012-08-08 12:05:02 +08:00
|
|
|
/**
|
2013-06-20 14:15:53 +08:00
|
|
|
@brief defines the object which users must packed for HttpClient::send(HttpRequest*) method.
|
2014-02-20 10:53:49 +08:00
|
|
|
Please refer to tests/test-cpp/Classes/ExtensionTest/NetworkTest/HttpClientTest.cpp as a sample
|
2012-08-08 12:05:02 +08:00
|
|
|
@since v2.0.2
|
|
|
|
*/
|
2013-04-26 11:42:50 +08:00
|
|
|
|
2014-03-29 02:26:41 +08:00
|
|
|
#if (CC_TARGET_PLATFORM == CC_PLATFORM_WP8) || (CC_TARGET_PLATFORM == CC_PLATFORM_WINRT)
|
|
|
|
#ifdef DELETE
|
|
|
|
#undef DELETE
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
|
2014-02-20 10:53:49 +08:00
|
|
|
class HttpRequest : public Ref
|
2012-08-07 18:28:07 +08:00
|
|
|
{
|
|
|
|
public:
|
|
|
|
/** Use this enum type as param in setReqeustType(param) */
|
2013-07-27 00:55:41 +08:00
|
|
|
enum class Type
|
|
|
|
{
|
|
|
|
GET,
|
|
|
|
POST,
|
|
|
|
PUT,
|
|
|
|
DELETE,
|
|
|
|
UNKNOWN,
|
|
|
|
};
|
2012-08-07 18:28:07 +08:00
|
|
|
|
2013-07-27 00:55:41 +08:00
|
|
|
/** Constructor
|
2012-08-08 12:05:02 +08:00
|
|
|
Because HttpRequest object will be used between UI thead and network thread,
|
2013-06-20 14:15:53 +08:00
|
|
|
requestObj->autorelease() is forbidden to avoid crashes in AutoreleasePool
|
2012-08-08 12:05:02 +08:00
|
|
|
new/retain/release still works, which means you need to release it manually
|
|
|
|
Please refer to HttpRequestTest.cpp to find its usage
|
|
|
|
*/
|
2013-06-20 14:15:53 +08:00
|
|
|
HttpRequest()
|
2012-08-07 18:28:07 +08:00
|
|
|
{
|
2013-07-27 00:55:41 +08:00
|
|
|
_requestType = Type::UNKNOWN;
|
2012-08-07 18:28:07 +08:00
|
|
|
_url.clear();
|
|
|
|
_requestData.clear();
|
|
|
|
_tag.clear();
|
2014-04-13 05:06:04 +08:00
|
|
|
_pTarget = nullptr;
|
|
|
|
_pSelector = nullptr;
|
|
|
|
_pCallback = nullptr;
|
|
|
|
_pUserData = nullptr;
|
2012-08-07 18:28:07 +08:00
|
|
|
};
|
|
|
|
|
2012-08-08 12:05:02 +08:00
|
|
|
/** Destructor */
|
2013-06-20 14:15:53 +08:00
|
|
|
virtual ~HttpRequest()
|
2012-08-07 18:28:07 +08:00
|
|
|
{
|
|
|
|
if (_pTarget)
|
|
|
|
{
|
|
|
|
_pTarget->release();
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2012-08-08 12:05:02 +08:00
|
|
|
/** Override autorelease method to avoid developers to call it */
|
2014-02-20 10:53:49 +08:00
|
|
|
Ref* autorelease(void)
|
2012-08-07 18:28:07 +08:00
|
|
|
{
|
2013-07-20 13:01:27 +08:00
|
|
|
CCASSERT(false, "HttpResponse is used between network thread and ui thread \
|
2012-08-07 18:28:07 +08:00
|
|
|
therefore, autorelease is forbidden here");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
// setter/getters for properties
|
2012-08-08 12:05:02 +08:00
|
|
|
|
|
|
|
/** Required field for HttpRequest object before being sent.
|
|
|
|
kHttpGet & kHttpPost is currently supported
|
|
|
|
*/
|
2013-07-27 00:55:41 +08:00
|
|
|
inline void setRequestType(Type type)
|
2012-08-07 18:28:07 +08:00
|
|
|
{
|
|
|
|
_requestType = type;
|
|
|
|
};
|
2012-08-08 12:05:02 +08:00
|
|
|
/** Get back the kHttpGet/Post/... enum value */
|
2013-07-27 00:55:41 +08:00
|
|
|
inline Type getRequestType()
|
2012-08-07 18:28:07 +08:00
|
|
|
{
|
|
|
|
return _requestType;
|
|
|
|
};
|
|
|
|
|
2012-08-08 12:05:02 +08:00
|
|
|
/** Required field for HttpRequest object before being sent.
|
|
|
|
*/
|
2012-08-07 18:28:07 +08:00
|
|
|
inline void setUrl(const char* url)
|
|
|
|
{
|
|
|
|
_url = url;
|
|
|
|
};
|
2012-08-08 12:05:02 +08:00
|
|
|
/** Get back the setted url */
|
2012-08-07 18:28:07 +08:00
|
|
|
inline const char* getUrl()
|
|
|
|
{
|
|
|
|
return _url.c_str();
|
|
|
|
};
|
|
|
|
|
2012-08-08 12:05:02 +08:00
|
|
|
/** Option field. You can set your post data here
|
|
|
|
*/
|
2014-03-20 16:24:55 +08:00
|
|
|
inline void setRequestData(const char* buffer, size_t len)
|
2012-08-07 18:28:07 +08:00
|
|
|
{
|
|
|
|
_requestData.assign(buffer, buffer + len);
|
|
|
|
};
|
2012-08-08 12:05:02 +08:00
|
|
|
/** Get the request data pointer back */
|
2012-08-07 18:28:07 +08:00
|
|
|
inline char* getRequestData()
|
|
|
|
{
|
2013-10-29 18:06:02 +08:00
|
|
|
if(_requestData.size() != 0)
|
|
|
|
return &(_requestData.front());
|
2013-10-29 17:54:35 +08:00
|
|
|
|
|
|
|
return nullptr;
|
2012-08-07 18:28:07 +08:00
|
|
|
}
|
2012-08-08 12:05:02 +08:00
|
|
|
/** Get the size of request data back */
|
2013-12-12 12:07:20 +08:00
|
|
|
inline ssize_t getRequestDataSize()
|
2012-08-07 18:28:07 +08:00
|
|
|
{
|
|
|
|
return _requestData.size();
|
|
|
|
}
|
|
|
|
|
2012-08-08 12:05:02 +08:00
|
|
|
/** Option field. You can set a string tag to identify your request, this tag can be found in HttpResponse->getHttpRequest->getTag()
|
|
|
|
*/
|
2012-08-07 18:28:07 +08:00
|
|
|
inline void setTag(const char* tag)
|
|
|
|
{
|
|
|
|
_tag = tag;
|
|
|
|
};
|
2012-08-08 12:05:02 +08:00
|
|
|
/** Get the string tag back to identify the request.
|
|
|
|
The best practice is to use it in your MyClass::onMyHttpRequestCompleted(sender, HttpResponse*) callback
|
|
|
|
*/
|
2012-08-07 18:28:07 +08:00
|
|
|
inline const char* getTag()
|
|
|
|
{
|
|
|
|
return _tag.c_str();
|
|
|
|
};
|
|
|
|
|
2012-08-08 12:05:02 +08:00
|
|
|
/** Option field. 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 manully
|
|
|
|
*/
|
2012-08-07 18:28:07 +08:00
|
|
|
inline void setUserData(void* pUserData)
|
|
|
|
{
|
|
|
|
_pUserData = pUserData;
|
|
|
|
};
|
2012-08-08 12:05:02 +08:00
|
|
|
/** Get the pre-setted custom data pointer back.
|
|
|
|
Don't forget to delete it. HttpClient/HttpResponse/HttpRequest will do nothing with this pointer
|
|
|
|
*/
|
2012-08-07 18:28:07 +08:00
|
|
|
inline void* getUserData()
|
|
|
|
{
|
|
|
|
return _pUserData;
|
|
|
|
};
|
|
|
|
|
2012-08-08 12:05:02 +08:00
|
|
|
/** Required field. You should set the callback selector function at ack the http request completed
|
|
|
|
*/
|
2014-02-20 10:53:49 +08:00
|
|
|
CC_DEPRECATED_ATTRIBUTE inline void setResponseCallback(Ref* pTarget, SEL_CallFuncND pSelector)
|
2013-04-26 11:42:50 +08:00
|
|
|
{
|
|
|
|
setResponseCallback(pTarget, (SEL_HttpResponse) pSelector);
|
|
|
|
}
|
|
|
|
|
2014-04-13 05:06:04 +08:00
|
|
|
CC_DEPRECATED_ATTRIBUTE inline void setResponseCallback(Ref* pTarget, SEL_HttpResponse pSelector)
|
2012-08-07 18:28:07 +08:00
|
|
|
{
|
|
|
|
_pTarget = pTarget;
|
|
|
|
_pSelector = pSelector;
|
|
|
|
|
|
|
|
if (_pTarget)
|
|
|
|
{
|
|
|
|
_pTarget->retain();
|
|
|
|
}
|
2014-04-13 05:06:04 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
inline void setResponseCallback(const ccHttpRequestCallback& callback)
|
|
|
|
{
|
|
|
|
_pCallback = callback;
|
|
|
|
}
|
|
|
|
|
2013-06-20 14:15:53 +08:00
|
|
|
/** Get the target of callback selector funtion, mainly used by HttpClient */
|
2014-02-20 10:53:49 +08:00
|
|
|
inline Ref* getTarget()
|
2012-08-07 18:28:07 +08:00
|
|
|
{
|
|
|
|
return _pTarget;
|
|
|
|
}
|
2013-04-26 11:42:50 +08:00
|
|
|
|
|
|
|
/* This sub class is just for migration SEL_CallFuncND to SEL_HttpResponse,
|
|
|
|
someday this way will be removed */
|
|
|
|
class _prxy
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
_prxy( SEL_HttpResponse cb ) :_cb(cb) {}
|
|
|
|
~_prxy(){};
|
|
|
|
operator SEL_HttpResponse() const { return _cb; }
|
2014-02-20 10:53:49 +08:00
|
|
|
CC_DEPRECATED_ATTRIBUTE operator SEL_CallFuncND() const { return (SEL_CallFuncND) _cb; }
|
2013-04-26 11:42:50 +08:00
|
|
|
protected:
|
|
|
|
SEL_HttpResponse _cb;
|
|
|
|
};
|
|
|
|
|
2013-06-20 14:15:53 +08:00
|
|
|
/** Get the selector function pointer, mainly used by HttpClient */
|
2013-04-26 11:42:50 +08:00
|
|
|
inline _prxy getSelector()
|
2012-08-07 18:28:07 +08:00
|
|
|
{
|
2013-04-26 11:42:50 +08:00
|
|
|
return _prxy(_pSelector);
|
2012-08-07 18:28:07 +08:00
|
|
|
}
|
2013-04-26 11:42:50 +08:00
|
|
|
|
2014-04-13 05:06:04 +08:00
|
|
|
inline const ccHttpRequestCallback& getCallback()
|
|
|
|
{
|
|
|
|
return _pCallback;
|
|
|
|
}
|
|
|
|
|
2012-09-22 22:45:02 +08:00
|
|
|
/** Set any custom headers **/
|
|
|
|
inline void setHeaders(std::vector<std::string> pHeaders)
|
|
|
|
{
|
|
|
|
_headers=pHeaders;
|
|
|
|
}
|
|
|
|
|
|
|
|
/** Get custom headers **/
|
|
|
|
inline std::vector<std::string> getHeaders()
|
|
|
|
{
|
|
|
|
return _headers;
|
|
|
|
}
|
2013-07-27 00:55:41 +08:00
|
|
|
|
2012-08-07 18:28:07 +08:00
|
|
|
protected:
|
|
|
|
// properties
|
2014-02-20 10:53:49 +08:00
|
|
|
Type _requestType; /// kHttpRequestGet, kHttpRequestPost or other enums
|
2012-08-07 18:28:07 +08:00
|
|
|
std::string _url; /// target url that this request is sent to
|
|
|
|
std::vector<char> _requestData; /// used for POST
|
|
|
|
std::string _tag; /// user defined tag, to identify different requests in response callback
|
2014-02-20 10:53:49 +08:00
|
|
|
Ref* _pTarget; /// callback target of pSelector function
|
2013-06-20 14:15:53 +08:00
|
|
|
SEL_HttpResponse _pSelector; /// callback function, e.g. MyLayer::onHttpResponse(HttpClient *sender, HttpResponse * response)
|
2014-04-13 05:06:04 +08:00
|
|
|
ccHttpRequestCallback _pCallback; /// C++11 style callbacks
|
2012-08-07 18:28:07 +08:00
|
|
|
void* _pUserData; /// You can add your customed data here
|
2012-09-22 22:45:02 +08:00
|
|
|
std::vector<std::string> _headers; /// custom http headers
|
2012-08-07 18:28:07 +08:00
|
|
|
};
|
|
|
|
|
2013-10-15 18:00:03 +08:00
|
|
|
}
|
2012-08-07 18:28:07 +08:00
|
|
|
|
2014-01-02 16:25:35 +08:00
|
|
|
NS_CC_END
|
|
|
|
|
2013-04-22 00:23:27 +08:00
|
|
|
#endif //__HTTP_REQUEST_H__
|