EXPORT_API void *create_instance()
{
- return (void *)NFCTerminal::getInstance();
+ int value;
+
+ if (vconf_get_bool(VCONFKEY_NFC_ESE_DISABLE, &value) < 0)
+ return NULL;
+
+ return value ? NULL : (void *)NFCTerminal::getInstance();
}
EXPORT_API void destroy_instance(void *instance)
finalize();
}
+ void NFCTerminal::onActivationChanged(bool activated, void *userData)
+ {
+ NFCTerminal *instance = (NFCTerminal *)userData;
+
+ _ERR("nfc state changed [%s]", activated ? "activated" : "deactivated");
+
+ if (activated == true) {
+ if (instance->present == false) {
+ if (instance->open() == true) {
+ instance->present = true;
+ instance->close();
+
+ if (instance->statusCallback != NULL) {
+ instance->statusCallback(
+ instance->getName(),
+ NOTIFY_SE_AVAILABLE,
+ SCARD_ERROR_OK,
+ NULL);
+ }
+ } else {
+ _ERR("ese open failed");
+ }
+ } else {
+ /* okay */
+ }
+ } else {
+ if (instance->present == true) {
+ instance->present = false;
+
+ if (instance->isClosed() == false) {
+ int ret;
+
+ /* close now */
+ ret = nfc_se_close_secure_element_internal(
+ instance->seHandle);
+ if (ret != NFC_ERROR_NONE) {
+ _ERR("nfc_se_close_secure_element failed [%d]", ret);
+ }
+
+ instance->seHandle = NULL;
+ instance->closed = true;
+ instance->referred = 0;
+ }
+
+ if (instance->statusCallback != NULL) {
+ instance->statusCallback(
+ instance->getName(),
+ NOTIFY_SE_NOT_AVAILABLE,
+ SCARD_ERROR_OK,
+ NULL);
+ }
+ } else {
+ /* okay */
+ }
+ }
+ }
+
bool NFCTerminal::initialize()
{
int ret;
if (initialized == true)
return initialized;
- ret = nfc_manager_initialize_sync();
+ ret = nfc_manager_initialize();
if (ret == NFC_ERROR_NONE)
{
initialized = true;
- if (open() == true) {
- present = true;
- close();
+ ret = nfc_manager_set_activation_changed_cb(
+ &NFCTerminal::onActivationChanged, this);
+ if (ret != NFC_ERROR_NONE) {
+ _ERR("nfc_manager_set_activation_changed_cb failed, [%d]", ret);
+ }
+
+ if (nfc_manager_is_activated() == true) {
+ if (open() == true) {
+ present = true;
+ close();
+ } else {
+ _ERR("ese open failed");
+ }
+ } else {
+ _ERR("nfc is not activated.");
}
}
else
if (isClosed() == false) {
/* close now */
- ret = nfc_se_close_secure_element(seHandle);
- if (ret == NFC_ERROR_NONE) {
- seHandle = NULL;
- closed = true;
- referred = 0;
- } else {
+ ret = nfc_se_close_secure_element_internal(seHandle);
+ if (ret != NFC_ERROR_NONE) {
_ERR("nfc_se_close_secure_element failed [%d]", ret);
}
+
+ seHandle = NULL;
+ closed = true;
+ referred = 0;
}
+ present = false;
+
+ nfc_manager_unset_activation_changed_cb();
+
ret = nfc_manager_deinitialize();
if (ret == NFC_ERROR_NONE) {
initialized = false;
if (isInitialized()) {
if (referred == 0) {
- ret = nfc_se_open_secure_element(NFC_SE_TYPE_ESE,
+ ret = nfc_se_open_secure_element_internal(NFC_SE_TYPE_ESE,
&seHandle);
if (ret == NFC_ERROR_NONE) {
closed = false;
referred++;
} else {
- _ERR("nfc_se_open_secure_element failed [%d]", ret);
+ _ERR("nfc_se_open_secure_element_internal failed [%d]", ret);
}
} else {
referred++;
if (isInitialized())
{
if (referred <= 1) {
- ret = nfc_se_close_secure_element(seHandle);
+ g_usleep(1000000);
+
+ ret = nfc_se_close_secure_element_internal(seHandle);
if (ret == NFC_ERROR_NONE) {
seHandle = NULL;
closed = true;
referred = 0;
} else {
- _ERR("nfc_se_close_secure_element failed [%d]", ret);
+ _ERR("nfc_se_close_secure_element_internal failed [%d]", ret);
}
} else {
referred--;
uint8_t *resp = NULL;
uint32_t resp_len;
- rv = nfc_se_send_apdu(seHandle,
+ rv = nfc_se_send_apdu_internal(seHandle,
(uint8_t *)command.getBuffer(),
command.size(),
&resp,
}
else
{
- _ERR("net_nfc_send_apdu_sync failed, [%d]", rv);
+ _ERR("nfc_se_send_apdu_internal failed, [%d]", rv);
}
}
else
uint8_t *temp = NULL;
uint32_t temp_len;
- rv = nfc_se_get_atr(seHandle, &temp, &temp_len);
+ rv = nfc_se_get_atr_internal(seHandle, &temp, &temp_len);
if (rv == NFC_ERROR_NONE && temp != NULL)
{
atr.assign(temp, temp_len);
- g_free(temp);
}
else
{
- _ERR("net_nfc_client_se_get_atr_sync failed");
+ _ERR("nfc_se_get_atr_internal failed");
}
+
+ if (temp != NULL)
+ g_free(temp);
}
else
{