if (handle == NULL)
{
- SCARD_DEBUG_ERR("ClientIPC::getInstance() failed");
+ _ERR("ClientIPC::getInstance() failed");
return;
}
closeSync();
}
- void ClientChannel::closeSync() throw(ErrorIO &, ErrorIllegalState &)
+ void ClientChannel::closeSync()
+ throw(ExceptionBase &, ErrorIO &, ErrorSecurity &,
+ ErrorIllegalState &, ErrorIllegalParameter &)
{
#ifdef CLIENT_IPC_THREAD
if (isClosed() == false)
msg.caller = (void *)this;
msg.callback = (void *)this; /* if callback is class instance, it means synchronized call */
- try
+ syncLock();
+ if (ClientIPC::getInstance().sendMessage(&msg) == true)
{
- syncLock();
- if (ClientIPC::getInstance().sendMessage(&msg) == true)
- {
- rv = waitTimedCondition(0);
- if (rv < 0)
- {
- SCARD_DEBUG_ERR("closeSync failed [%d]", rv);
- }
- }
- else
+ rv = waitTimedCondition(0);
+ if (rv < 0)
{
- SCARD_DEBUG_ERR("sendMessage failed");
- throw ErrorIO(SCARD_ERROR_IPC_FAILED);
+ _ERR("timeout [%d]", rv);
+ this->error = SCARD_ERROR_OPERATION_TIMEOUT;
}
- syncUnlock();
}
- catch (ExceptionBase &e)
+ else
{
- syncUnlock();
-
- throw e;
+ _ERR("sendMessage failed");
+ this->error = SCARD_ERROR_IPC_FAILED;
}
+ syncUnlock();
channelNum = -1;
+
+ if (this->error != SCARD_ERROR_OK)
+ {
+ ThrowError::throwError(this->error);
+ }
}
else
{
- SCARD_DEBUG_ERR("unavailable channel");
+ _INFO("unavailable channel");
}
}
#endif
int ClientChannel::close(closeCallback callback, void *userParam)
{
- int result = 0;
+ int result = SCARD_ERROR_OK;
if (isClosed() == false)
{
msg.callback = (void *)callback;
msg.userParam = userParam;
- if (ClientIPC::getInstance().sendMessage(&msg) == true)
+ if (ClientIPC::getInstance().sendMessage(&msg) == false)
{
- result = 0;
- }
- else
- {
- result = -1;
+ _ERR("sendMessage failed");
+ result = SCARD_ERROR_IPC_FAILED;
}
}
else
{
- SCARD_DEBUG_ERR("unavailable channel");
- result = -1;
+ _ERR("unavailable channel");
+ result = SCARD_ERROR_ILLEGAL_STATE;
}
}
}
int ClientChannel::transmitSync(ByteArray command, ByteArray &result)
- throw(ErrorIO &, ErrorIllegalState &, ErrorIllegalParameter &, ErrorSecurity &)
+ throw(ExceptionBase &, ErrorIO &, ErrorIllegalState &,
+ ErrorIllegalParameter &, ErrorSecurity &)
{
- int rv = -1;
+ int rv = SCARD_ERROR_OK;
if (getSession()->getReader()->isSecureElementPresent() == true)
{
Message msg;
if (rv >= 0)
{
result = response;
-
- rv = 0;
+ rv = SCARD_ERROR_OK;
}
else
{
- SCARD_DEBUG_ERR("timeout");
-
- rv = -1;
+ _ERR("timeout [%d]", rv);
+ this->error = SCARD_ERROR_OPERATION_TIMEOUT;
}
}
else
{
- SCARD_DEBUG_ERR("sendMessage failed");
+ _ERR("sendMessage failed");
}
syncUnlock();
+
+ if (this->error != SCARD_ERROR_OK)
+ {
+ ThrowError::throwError(this->error);
+ }
#endif
}
else
{
- SCARD_DEBUG_ERR("unavailable channel");
+ _ERR("unavailable channel");
throw ErrorIllegalState(SCARD_ERROR_UNAVAILABLE);
}
int ClientChannel::transmit(ByteArray command, transmitCallback callback, void *userParam)
{
- int result = -1;
+ int result;
if (getSession()->getReader()->isSecureElementPresent() == true)
{
if (ClientIPC::getInstance().sendMessage(&msg) == true)
{
- result = 0;
+ result = SCARD_ERROR_OK;
}
else
{
- result = -1;
+ _ERR("sendMessage failed");
+ result = SCARD_ERROR_IPC_FAILED;
}
}
else
{
- SCARD_DEBUG_ERR("unavailable channel");
+ _ERR("unavailable channel");
+ result = SCARD_ERROR_ILLEGAL_STATE;
}
return result;
if (msg == NULL)
{
- SCARD_DEBUG_ERR("message is null");
+ _ERR("message is null");
return result;
}
case Message::MSG_REQUEST_TRANSMIT :
{
/* transmit result */
- SCARD_DEBUG("MSG_REQUEST_TRANSMIT");
-
- if (msg->error == 0 &&
- ResponseHelper::getStatus(msg->data) == 0)
- {
- /* store select response */
- if (msg->data.getAt(1) == APDUCommand::INS_SELECT_FILE)
- channel->setSelectResponse(msg->data);
- }
+ _INFO("MSG_REQUEST_TRANSMIT");
if (msg->isSynchronousCall() == true) /* synchronized call */
{
case Message::MSG_REQUEST_CLOSE_CHANNEL :
{
- SCARD_DEBUG("MSG_REQUEST_CLOSE_CHANNEL");
+ _INFO("MSG_REQUEST_CLOSE_CHANNEL");
if (msg->isSynchronousCall() == true) /* synchronized call */
{
break;
default:
- SCARD_DEBUG("unknwon message : %s", msg->toString());
+ _DBG("Unknown message : %s", msg->toString());
break;
}
+ delete msg;
+
return result;
}
} /* namespace smartcard_service_api */
} \
else \
{ \
- SCARD_DEBUG_ERR("Invalid param"); \
+ _ERR("Invalid param"); \
}
using namespace smartcard_service_api;