2013-04-25 17:33:42 +08:00
|
|
|
/****************************************************************************
|
|
|
|
Copyright (c) 2012-2013 cocos2d-x.org
|
|
|
|
|
|
|
|
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.
|
|
|
|
****************************************************************************/
|
2013-04-07 16:58:26 +08:00
|
|
|
#include "ProtocolIAP.h"
|
|
|
|
#include "PluginJniHelper.h"
|
|
|
|
#include <android/log.h>
|
|
|
|
#include "PluginUtils.h"
|
|
|
|
#include "PluginJavaData.h"
|
|
|
|
|
|
|
|
#if 1
|
|
|
|
#define LOG_TAG "ProtocolIAP"
|
|
|
|
#define LOGD(...) __android_log_print(ANDROID_LOG_DEBUG,LOG_TAG,__VA_ARGS__)
|
|
|
|
#else
|
|
|
|
#define LOGD(...)
|
|
|
|
#endif
|
|
|
|
|
|
|
|
namespace cocos2d { namespace plugin {
|
|
|
|
|
|
|
|
extern "C" {
|
2013-05-16 11:45:46 +08:00
|
|
|
JNIEXPORT void JNICALL Java_org_cocos2dx_plugin_InterfaceIAP_nativeOnPayResult(JNIEnv* env, jobject thiz, jstring className, jint ret, jstring msg)
|
2013-04-07 16:58:26 +08:00
|
|
|
{
|
|
|
|
std::string strMsg = PluginJniHelper::jstring2string(msg);
|
2013-05-16 11:45:46 +08:00
|
|
|
std::string strClassName = PluginJniHelper::jstring2string(className);
|
|
|
|
PluginProtocol* pPlugin = PluginUtils::getPluginPtr(strClassName);
|
2013-04-26 17:12:51 +08:00
|
|
|
LOGD("nativeOnPayResult(), Get plugin ptr : %p", pPlugin);
|
2013-04-25 17:33:42 +08:00
|
|
|
if (pPlugin != NULL)
|
|
|
|
{
|
2013-04-26 17:12:51 +08:00
|
|
|
LOGD("nativeOnPayResult(), Get plugin name : %s", pPlugin->getPluginName());
|
2013-04-25 17:33:42 +08:00
|
|
|
ProtocolIAP* pIAP = dynamic_cast<ProtocolIAP*>(pPlugin);
|
|
|
|
if (pIAP != NULL)
|
|
|
|
{
|
2013-04-26 17:12:51 +08:00
|
|
|
pIAP->onPayResult((PayResultCode) ret, strMsg.c_str());
|
2013-04-25 17:33:42 +08:00
|
|
|
}
|
|
|
|
}
|
2013-04-07 16:58:26 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
bool ProtocolIAP::m_bPaying = false;
|
|
|
|
|
|
|
|
ProtocolIAP::ProtocolIAP()
|
2013-04-25 17:33:42 +08:00
|
|
|
: m_pListener(NULL)
|
2013-04-07 16:58:26 +08:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
ProtocolIAP::~ProtocolIAP()
|
|
|
|
{
|
|
|
|
PluginUtils::erasePluginJavaData(this);
|
|
|
|
}
|
|
|
|
|
|
|
|
bool ProtocolIAP::init()
|
|
|
|
{
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2013-04-26 17:12:51 +08:00
|
|
|
void ProtocolIAP::configDeveloperInfo(TIAPDeveloperInfo devInfo)
|
2013-04-07 16:58:26 +08:00
|
|
|
{
|
|
|
|
if (devInfo.empty())
|
|
|
|
{
|
|
|
|
LOGD("The developer info is empty!");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
PluginJavaData* pData = PluginUtils::getPluginJavaData(this);
|
|
|
|
PluginJniMethodInfo t;
|
|
|
|
if (PluginJniHelper::getMethodInfo(t
|
|
|
|
, pData->jclassName.c_str()
|
2013-04-26 17:12:51 +08:00
|
|
|
, "configDeveloperInfo"
|
2013-04-07 16:58:26 +08:00
|
|
|
, "(Ljava/util/Hashtable;)V"))
|
|
|
|
{
|
|
|
|
// generate the hashtable from map
|
|
|
|
jobject obj_Map = PluginUtils::createJavaMapObject(t, &devInfo);
|
|
|
|
|
|
|
|
// invoke java method
|
|
|
|
t.env->CallVoidMethod(pData->jobj, t.methodID, obj_Map);
|
|
|
|
t.env->DeleteLocalRef(obj_Map);
|
|
|
|
t.env->DeleteLocalRef(t.classID);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void ProtocolIAP::payForProduct(TProductInfo info)
|
|
|
|
{
|
|
|
|
if (m_bPaying)
|
|
|
|
{
|
|
|
|
LOGD("Now is paying");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (info.empty())
|
|
|
|
{
|
|
|
|
if (NULL != m_pListener)
|
|
|
|
{
|
2013-04-26 17:12:51 +08:00
|
|
|
onPayResult(kPayFail, "Product info error");
|
2013-04-07 16:58:26 +08:00
|
|
|
}
|
|
|
|
LOGD("The product info is empty!");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
m_bPaying = true;
|
|
|
|
m_curInfo = info;
|
|
|
|
|
|
|
|
PluginJavaData* pData = PluginUtils::getPluginJavaData(this);
|
|
|
|
PluginJniMethodInfo t;
|
|
|
|
if (PluginJniHelper::getMethodInfo(t
|
|
|
|
, pData->jclassName.c_str()
|
|
|
|
, "payForProduct"
|
|
|
|
, "(Ljava/util/Hashtable;)V"))
|
|
|
|
{
|
|
|
|
// generate the hashtable from map
|
|
|
|
jobject obj_Map = PluginUtils::createJavaMapObject(t, &info);
|
|
|
|
|
|
|
|
// invoke java method
|
|
|
|
t.env->CallVoidMethod(pData->jobj, t.methodID, obj_Map);
|
|
|
|
t.env->DeleteLocalRef(obj_Map);
|
|
|
|
t.env->DeleteLocalRef(t.classID);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void ProtocolIAP::setResultListener(PayResultListener* pListener)
|
|
|
|
{
|
|
|
|
m_pListener = pListener;
|
|
|
|
}
|
|
|
|
|
2013-04-26 17:12:51 +08:00
|
|
|
void ProtocolIAP::onPayResult(PayResultCode ret, const char* msg)
|
2013-04-07 16:58:26 +08:00
|
|
|
{
|
|
|
|
m_bPaying = false;
|
|
|
|
if (m_pListener)
|
|
|
|
{
|
2013-04-26 17:12:51 +08:00
|
|
|
m_pListener->onPayResult(ret, msg, m_curInfo);
|
2013-04-07 16:58:26 +08:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
LOGD("Result listener is null!");
|
|
|
|
}
|
|
|
|
m_curInfo.clear();
|
|
|
|
LOGD("Pay result is : %d(%s)", (int) ret, msg);
|
|
|
|
}
|
|
|
|
|
|
|
|
const char* ProtocolIAP::getSDKVersion()
|
|
|
|
{
|
|
|
|
std::string verName;
|
|
|
|
|
|
|
|
PluginJavaData* pData = PluginUtils::getPluginJavaData(this);
|
|
|
|
PluginJniMethodInfo t;
|
|
|
|
if (PluginJniHelper::getMethodInfo(t
|
|
|
|
, pData->jclassName.c_str()
|
|
|
|
, "getSDKVersion"
|
|
|
|
, "()Ljava/lang/String;"))
|
|
|
|
{
|
|
|
|
jstring ret = (jstring)(t.env->CallObjectMethod(pData->jobj, t.methodID));
|
|
|
|
verName = PluginJniHelper::jstring2string(ret);
|
|
|
|
}
|
|
|
|
return verName.c_str();
|
|
|
|
}
|
|
|
|
|
|
|
|
void ProtocolIAP::setDebugMode(bool debug)
|
|
|
|
{
|
|
|
|
PluginUtils::callJavaFunctionWithName_oneBaseType(this, "setDebugMode", "(Z)V", debug);
|
|
|
|
}
|
|
|
|
|
|
|
|
}} // namespace cocos2d { namespace plugin {
|