From 223800a5eb76780e495b76bad524fd1339bbf199 Mon Sep 17 00:00:00 2001 From: "jk7744.park" Date: Tue, 8 Sep 2015 22:38:31 +0900 Subject: [PATCH] tizen 2.3.1 release --- AUTHOR | 5 + CMakeLists.txt | 12 +- LICENSE => LICENSE.APLv2 | 0 NFCTerminal.cpp | 421 ++++++++++++------------------------ NOTICE | 3 + include/NFCTerminal.h | 56 ++--- packaging/smartcard-plugin-nfc | 206 ++++++++++++++++++ packaging/smartcard-plugin-nfc.spec | 55 ++--- smartcard-plugin-nfc.manifest | 6 + 9 files changed, 419 insertions(+), 345 deletions(-) create mode 100644 AUTHOR rename LICENSE => LICENSE.APLv2 (100%) create mode 100644 NOTICE create mode 100644 packaging/smartcard-plugin-nfc create mode 100644 smartcard-plugin-nfc.manifest diff --git a/AUTHOR b/AUTHOR new file mode 100644 index 0000000..50ea802 --- /dev/null +++ b/AUTHOR @@ -0,0 +1,5 @@ +Lee Sangsoo +Junyong Sim +Wonkyu Kwon +Sungjae Lim +Sechang Sohn diff --git a/CMakeLists.txt b/CMakeLists.txt index f973d6d..a150417 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -14,14 +14,13 @@ AUX_SOURCE_DIRECTORY(${CMAKE_CURRENT_SOURCE_DIR} SRCS) #MESSAGE("Build type: ${CMAKE_BUILD_TYPE}") INCLUDE(FindPkgConfig) -pkg_check_modules(pkgs_common REQUIRED dlog smartcard-service-common nfc) +pkg_check_modules(pkgs_common REQUIRED glib-2.0 dlog smartcard-service-common capi-network-nfc) FOREACH(flag ${pkgs_common_CFLAGS}) SET(EXTRA_CXXFLAGS "${EXTRA_CXXFLAGS} ${flag}") ENDFOREACH(flag) -#SET(EXTRA_CFLAGS "${EXTRA_CFLAGS} -finstrument-functions") -SET(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} ${EXTRA_CXXFLAGS}") +SET(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} ${EXTRA_CXXFLAGS} -finstrument-functions -std=c++0x") #SET(CMAKE_C_FLAGS_DEBUG "-O0 -g") #SET(CMAKE_C_FLAGS_RELEASE "-O2") @@ -38,10 +37,7 @@ MESSAGE("CMAKE_LD_FLAGS: ${pkgs_common_LDFLAGS}") MESSAGE("CMAKE_INSTALL_PREFIX: ${CMAKE_INSTALL_PREFIX}") ADD_DEFINITIONS("-DPREFIX=\"${CMAKE_INSTALL_PREFIX}\"") ADD_DEFINITIONS("-DSLP_DEBUG") - -ADD_DEFINITIONS("-DLOG_TAG=\"SCARD_SE_NFC\"") - -SET(CMAKE_EXE_LINKER_FLAGS "-Wl,--as-needed") +ADD_DEFINITIONS("-DLOG_TAG=\"SMARTCARD_PLUGIN_NFC\"") ADD_LIBRARY(${PROJECT_NAME} SHARED ${SRCS}) @@ -50,4 +46,4 @@ ADD_LIBRARY(${PROJECT_NAME} SHARED ${SRCS}) TARGET_LINK_LIBRARIES(${PROJECT_NAME} ${pkgs_common_LDFLAGS}) -INSTALL(TARGETS ${PROJECT_NAME} DESTINATION lib/se) \ No newline at end of file +INSTALL(TARGETS ${PROJECT_NAME} DESTINATION lib/se) diff --git a/LICENSE b/LICENSE.APLv2 similarity index 100% rename from LICENSE rename to LICENSE.APLv2 diff --git a/NFCTerminal.cpp b/NFCTerminal.cpp index 09b6fff..e96d1ac 100644 --- a/NFCTerminal.cpp +++ b/NFCTerminal.cpp @@ -1,31 +1,32 @@ /* -* Copyright (c) 2012 Samsung Electronics Co., Ltd All Rights Reserved -* -* Licensed under the Apache License, Version 2.0 (the "License"); -* you may not use this file except in compliance with the License. -* You may obtain a copy of the License at -* -* http://www.apache.org/licenses/LICENSE-2.0 -* -* Unless required by applicable law or agreed to in writing, software -* distributed under the License is distributed on an "AS IS" BASIS, -* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -* See the License for the specific language governing permissions and -* limitations under the License. -*/ - + * Copyright (c) 2012, 2013 Samsung Electronics Co., Ltd. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ /* standard library header */ -#include +#include +#include #include -#include #include +#include /* SLP library header */ -#include "net_nfc.h" -#include "net_nfc_internal_se.h" +#include "nfc.h" +#include "nfc_internal.h" /* local header */ +#include "smartcard-types.h" #include "Debug.h" #include "TerminalInterface.h" #include "NFCTerminal.h" @@ -34,6 +35,8 @@ #define EXPORT_API __attribute__((visibility("default"))) #endif +#define ASYNC + using namespace smartcard_service_api; static const char *se_name = "eSE"; @@ -47,42 +50,43 @@ void __attribute__ ((destructor)) lib_fini() { } -/* below trhee functions must be implemented */ -extern "C" EXPORT_API const char *get_name() +/* below three functions must be implemented */ +extern "C" +{ +EXPORT_API const char *get_name() { return se_name; } -extern "C" EXPORT_API void *create_instance() +EXPORT_API void *create_instance() { return (void *)NFCTerminal::getInstance(); } -extern "C" EXPORT_API void destroy_instance(void *instance) +EXPORT_API void destroy_instance(void *instance) { NFCTerminal *inst = (NFCTerminal *)instance; + if (inst == NFCTerminal::getInstance()) { inst->finalize(); } else { - SCARD_DEBUG_ERR("instance is invalid : getInstance [%p], instance [%p]", NFCTerminal::getInstance(), instance); + _ERR("instance is invalid : getInstance [%p], instance [%p]", + NFCTerminal::getInstance(), instance); } } +} namespace smartcard_service_api { - NFCTerminal::NFCTerminal():Terminal() + NFCTerminal::NFCTerminal() : Terminal(), seHandle(NULL), + present(false), referred(0) { - seHandle = NULL; - closed = true; name = (char *)se_name; - if (initialize()) - { - open(); - } + initialize(); } NFCTerminal *NFCTerminal::getInstance() @@ -99,323 +103,184 @@ namespace smartcard_service_api bool NFCTerminal::initialize() { - int ret = 0; + int ret; - if (initialized == false) - { - if ((ret = net_nfc_initialize()) == NET_NFC_OK) - { - net_nfc_state_activate(1); + if (initialized == true) + return initialized; - if ((ret = net_nfc_set_response_callback(&NFCTerminal::nfcResponseCallback, this)) == NET_NFC_OK) - { - SCARD_DEBUG("nfc initialize success"); + ret = nfc_manager_initialize(); + if (ret == NFC_ERROR_NONE) + { + initialized = true; - initialized = true; - } - else - { - SCARD_DEBUG_ERR("net_nfc_set_response_callback failed [%d]", ret); - } - } - else - { - SCARD_DEBUG_ERR("net_nfc_initialize failed [%d]", ret); + if (open() == true) { + present = true; + close(); } } + else + { + _ERR("net_nfc_initialize failed [%d]", ret); + } return initialized; } void NFCTerminal::finalize() { - net_nfc_error_e ret; - - if (seHandle != NULL) - { - net_nfc_close_internal_secure_element(seHandle, this); + int ret; + + if (isClosed() == false) { + /* close now */ + 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); + } } - net_nfc_deinitialize(); + ret = nfc_manager_deinitialize(); + if (ret == NFC_ERROR_NONE) { + initialized = false; + } else { + _ERR("nfc_manager_deinitialize failed [%d]", ret); + } } bool NFCTerminal::open() { - bool result = false; - net_nfc_error_e ret; - int rv; - - SCARD_BEGIN(); - - if (isClosed() == true) - { - if ((ret = net_nfc_open_internal_secure_element(NET_NFC_SE_TYPE_ESE, this)) == NET_NFC_OK) - { -#ifndef ASYNC - syncLock(); - if ((rv = waitTimedCondition(3)) == 0 && error == NET_NFC_OK) - { -#endif - result = true; - SCARD_DEBUG("net_nfc_open_internal_secure_element returns [%d]", ret); -#ifndef ASYNC + int ret; + + _BEGIN(); + + if (isInitialized()) { + if (referred == 0) { + 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); } - else - { - SCARD_DEBUG_ERR("net_nfc_open_internal_secure_element failed cbResult [%d], rv [%d]", error, rv); - } - syncUnlock(); -#endif - } - else - { - SCARD_DEBUG_ERR("net_nfc_set_secure_element_type failed [%d]", ret); + } else { + referred++; } + + _DBG("reference count [%d]", referred); } - SCARD_END(); + _END(); - return result; + return (isClosed() == false); } void NFCTerminal::close() { - net_nfc_error_e ret; - int rv; + int ret; - SCARD_BEGIN(); + _BEGIN(); - if (isInitialized() && isClosed() == false && seHandle != NULL) + if (isInitialized()) { - if ((ret = net_nfc_close_internal_secure_element(seHandle, this)) == NET_NFC_OK) - { - #ifndef ASYNC - syncLock(); - if ((rv = waitTimedCondition(3)) == 0 && error == NET_NFC_OK) - { - #endif - SCARD_DEBUG("net_nfc_close_internal_secure_element returns [%d]", ret); - #ifndef ASYNC + if (referred <= 1) { + 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); } - else - { - SCARD_DEBUG_ERR("net_nfc_close_internal_secure_element failed, error [%d], rv [%d]", error, rv); - } - syncUnlock(); - #endif + } else { + referred--; } - else - { - SCARD_DEBUG_ERR("net_nfc_close_internal_secure_element failed [%d]", ret); - } - } - SCARD_END(); - } + _DBG("reference count [%d]", referred); + } - bool NFCTerminal::isClosed() - { - return closed; + _END(); } - int NFCTerminal::transmitSync(ByteArray command, ByteArray &response) + int NFCTerminal::transmitSync(const ByteArray &command, ByteArray &response) { - int rv = 0; - data_h data; + int rv = SCARD_ERROR_NOT_INITIALIZED; - SCARD_BEGIN(); + _BEGIN(); - SCOPE_LOCK(mutex) + if (isClosed() == false) { - if (command.getLength() > 0) + if (command.size() > 0) { - SCARD_DEBUG("command : %s", command.toString()); - -#ifndef ASYNC - response.releaseBuffer(); -#endif - net_nfc_create_data(&data, command.getBuffer(), command.getLength()); - net_nfc_send_apdu(seHandle, data, this); -#ifndef ASYNC - syncLock(); - rv = waitTimedCondition(3); - - if (rv == 0 && error == NET_NFC_OK) + uint8_t *resp = NULL; + uint32_t resp_len; + + rv = nfc_se_send_apdu_internal(seHandle, + (uint8_t *)command.getBuffer(), + command.size(), + &resp, + &resp_len); + if (rv == NFC_ERROR_NONE && + resp != NULL) { - if (response.getLength() > 0) - { - response = response; - } + response.assign(resp, resp_len); - SCARD_DEBUG("transmit success, length [%d]", response.getLength()); + g_free(resp); } else { - SCARD_DEBUG_ERR("transmit failed, rv [%d], cbResult [%d]", rv, error); + _ERR("net_nfc_send_apdu_sync failed, [%d]", rv); } - syncUnlock(); - - rv = error; -#endif } else { - rv = -1; + _ERR("invalid command"); } } - - SCARD_END(); - - return rv; - } - - int NFCTerminal::getATRSync(ByteArray &atr) - { - int rv = 0; - - SCARD_BEGIN(); - - SCOPE_LOCK(mutex) + else { + _ERR("closed..."); } - SCARD_END(); + _END(); return rv; } - bool NFCTerminal::isSecureElementPresence() - { - return (seHandle != NULL); - } - - void NFCTerminal::nfcResponseCallback(net_nfc_message_e message, net_nfc_error_e result, void *data , void *userContext, void *transData) + int NFCTerminal::getATRSync(ByteArray &atr) { - NFCTerminal *instance = (NFCTerminal *)userContext; + int rv = -1; - SCARD_BEGIN(); + _BEGIN(); - if (instance == NULL) + if (isClosed() == false) { - SCARD_DEBUG_ERR("instance is null"); - return; - } - - switch(message) - { - case NET_NFC_MESSAGE_SET_SE : - SCARD_DEBUG("NET_NFC_MESSAGE_SET_SE"); - break; - - case NET_NFC_MESSAGE_GET_SE : - SCARD_DEBUG("NET_NFC_MESSAGE_GET_SE"); - break; - - case NET_NFC_MESSAGE_OPEN_INTERNAL_SE : - SCARD_DEBUG("NET_NFC_MESSAGE_OPEN_INTERNAL_SE"); + uint8_t *temp = NULL; + uint32_t temp_len; - if (result == NET_NFC_OK) - { - if (data != NULL) - { - instance->seHandle = (net_nfc_target_handle_h)data; - instance->closed = false; - } - else - { - SCARD_DEBUG_ERR("NET_NFC_MESSAGE_OPEN_INTERNAL_SE failed"); - } - } - else + rv = nfc_se_get_atr_internal(seHandle, &temp, &temp_len); + if (rv == NFC_ERROR_NONE && + temp != NULL) { - SCARD_DEBUG_ERR("NET_NFC_MESSAGE_OPEN_INTERNAL_SE returns error [%d]", result); - } - - instance->error = result; + atr.assign(temp, temp_len); - instance->syncLock(); - instance->signalCondition(); - instance->syncUnlock(); - break; - - case NET_NFC_MESSAGE_CLOSE_INTERNAL_SE : - SCARD_DEBUG("NET_NFC_MESSAGE_CLOSE_INTERNAL_SE"); - - if (result == NET_NFC_OK) - { - instance->closed = true; + g_free(temp); } else { - SCARD_DEBUG_ERR("NET_NFC_MESSAGE_CLOSE_INTERNAL_SE failed [%d]", result); - } - - instance->error = result; - - instance->syncLock(); - instance->signalCondition(); - instance->syncUnlock(); - break; - - case NET_NFC_MESSAGE_SEND_APDU_SE : - { - data_h resp = (data_h)data; - - SCARD_DEBUG("NET_NFC_MESSAGE_SEND_APDU_SE"); - - if (result == NET_NFC_OK) - { - if (resp != NULL) - { - SCARD_DEBUG("apdu result length [%d]", net_nfc_get_data_length(resp)); - instance->response.setBuffer(net_nfc_get_data_buffer(resp), net_nfc_get_data_length(resp)); - } - } - else - { - SCARD_DEBUG_ERR("NET_NFC_MESSAGE_OPEN_INTERNAL_SE failed [%d]", result); - } - - instance->error = result; - - instance->syncLock(); - instance->signalCondition(); - instance->syncUnlock(); + _ERR("net_nfc_client_se_get_atr_sync failed"); } - break; - -// case NFC_ON_NOTI_CASE : -// { -// finalize(); -// -// /* send notification */ -// if (instance->statusCallback != NULL) -// { -// instance->statusCallback(se_name, NOTIFY_SE_AVAILABLE, 0, NULL); -// } -// } -// break; -// -// case NFC_OFF_NOTI_CASE : -// { -// initialize(); -// if (open() == true) -// { -// /* send notification */ -// if (instance->statusCallback != NULL) -// { -// instance->statusCallback(se_name, NOTIFY_SE_NOT_AVAILABLE, 0, NULL); -// } -// } -// } -// break; - - default: - SCARD_DEBUG("unknown message : [%d], [%d], [%p], [%p], [%p]", message, result, data, userContext, instance); - break; + } + else + { + _ERR("closed..."); } - SCARD_END(); + _END(); + + return rv; } } /* namespace smartcard_service_api */ - diff --git a/NOTICE b/NOTICE new file mode 100644 index 0000000..0e0f016 --- /dev/null +++ b/NOTICE @@ -0,0 +1,3 @@ +Copyright (c) Samsung Electronics Co., Ltd. All rights reserved. +Except as noted, this software is licensed under Apache License, Version 2. +Please, see the LICENSE.APLv2 file for Apache License terms and conditions. diff --git a/include/NFCTerminal.h b/include/NFCTerminal.h index 0764797..c99ffa1 100644 --- a/include/NFCTerminal.h +++ b/include/NFCTerminal.h @@ -1,19 +1,18 @@ /* -* Copyright (c) 2012 Samsung Electronics Co., Ltd All Rights Reserved -* -* Licensed under the Apache License, Version 2.0 (the "License"); -* you may not use this file except in compliance with the License. -* You may obtain a copy of the License at -* -* http://www.apache.org/licenses/LICENSE-2.0 -* -* Unless required by applicable law or agreed to in writing, software -* distributed under the License is distributed on an "AS IS" BASIS, -* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -* See the License for the specific language governing permissions and -* limitations under the License. -*/ - + * Copyright (c) 2012, 2013 Samsung Electronics Co., Ltd. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ #ifndef NFCTERMINAL_H_ #define NFCTERMINAL_H_ @@ -21,7 +20,7 @@ /* standard library header */ /* SLP library header */ -#include "net_nfc_typedef.h" +#include "nfc.h" /* local header */ #include "Terminal.h" @@ -29,42 +28,33 @@ namespace smartcard_service_api { - class NFCTerminal: public Terminal + class NFCTerminal : public Terminal { private: PMutex mutex; - net_nfc_target_handle_h seHandle; - bool closed; - /* temporary data for sync function */ - ByteArray response; - int error; + nfc_se_h seHandle; + bool present; + int referred; NFCTerminal(); ~NFCTerminal(); - static void nfcResponseCallback(net_nfc_message_e message, net_nfc_error_e result, void *data , void *userContext, void *transData); - public: - static NFCTerminal *getInstance(); bool initialize(); void finalize(); bool open(); - bool isClosed(); void close(); - bool isSecureElementPresence(); + bool isSecureElementPresence() const { return present; } - int transmitSync(ByteArray command, ByteArray &response); + int transmitSync(const ByteArray &command, ByteArray &response); int getATRSync(ByteArray &atr); - int transmit(ByteArray command, terminalTransmitCallback callback, void *userParam) { return -1; }; - int getATR(terminalGetATRCallback callback, void *userParam) { return -1; } - - friend void nfcResponseCallback(net_nfc_message_e message, net_nfc_error_e result, void *data , void *userContext, void *transData); + int transmit(const ByteArray &command, terminalTransmitCallback callback, void *userParam) { return SCARD_ERROR_NOT_SUPPORTED; }; + int getATR(terminalGetATRCallback callback, void *userParam) { return SCARD_ERROR_NOT_SUPPORTED; } }; - } /* namespace smartcard_service_api */ #endif /* NFCTERMINAL_H_ */ diff --git a/packaging/smartcard-plugin-nfc b/packaging/smartcard-plugin-nfc new file mode 100644 index 0000000..ec68963 --- /dev/null +++ b/packaging/smartcard-plugin-nfc @@ -0,0 +1,206 @@ +Copyright (c) 2000 - 2012 Samsung Electronics Co., Ltd. All rights reserved. + + Apache License + Version 2.0, January 2004 + http://www.apache.org/licenses/ + + TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION + + 1. Definitions. + + "License" shall mean the terms and conditions for use, reproduction, + and distribution as defined by Sections 1 through 9 of this document. + + "Licensor" shall mean the copyright owner or entity authorized by + the copyright owner that is granting the License. + + "Legal Entity" shall mean the union of the acting entity and all + other entities that control, are controlled by, or are under common + control with that entity. For the purposes of this definition, + "control" means (i) the power, direct or indirect, to cause the + direction or management of such entity, whether by contract or + otherwise, or (ii) ownership of fifty percent (50%) or more of the + outstanding shares, or (iii) beneficial ownership of such entity. + + "You" (or "Your") shall mean an individual or Legal Entity + exercising permissions granted by this License. + + "Source" form shall mean the preferred form for making modifications, + including but not limited to software source code, documentation + source, and configuration files. + + "Object" form shall mean any form resulting from mechanical + transformation or translation of a Source form, including but + not limited to compiled object code, generated documentation, + and conversions to other media types. + + "Work" shall mean the work of authorship, whether in Source or + Object form, made available under the License, as indicated by a + copyright notice that is included in or attached to the work + (an example is provided in the Appendix below). + + "Derivative Works" shall mean any work, whether in Source or Object + form, that is based on (or derived from) the Work and for which the + editorial revisions, annotations, elaborations, or other modifications + represent, as a whole, an original work of authorship. For the purposes + of this License, Derivative Works shall not include works that remain + separable from, or merely link (or bind by name) to the interfaces of, + the Work and Derivative Works thereof. + + "Contribution" shall mean any work of authorship, including + the original version of the Work and any modifications or additions + to that Work or Derivative Works thereof, that is intentionally + submitted to Licensor for inclusion in the Work by the copyright owner + or by an individual or Legal Entity authorized to submit on behalf of + the copyright owner. For the purposes of this definition, "submitted" + means any form of electronic, verbal, or written communication sent + to the Licensor or its representatives, including but not limited to + communication on electronic mailing lists, source code control systems, + and issue tracking systems that are managed by, or on behalf of, the + Licensor for the purpose of discussing and improving the Work, but + excluding communication that is conspicuously marked or otherwise + designated in writing by the copyright owner as "Not a Contribution." + + "Contributor" shall mean Licensor and any individual or Legal Entity + on behalf of whom a Contribution has been received by Licensor and + subsequently incorporated within the Work. + + 2. Grant of Copyright License. Subject to the terms and conditions of + this License, each Contributor hereby grants to You a perpetual, + worldwide, non-exclusive, no-charge, royalty-free, irrevocable + copyright license to reproduce, prepare Derivative Works of, + publicly display, publicly perform, sublicense, and distribute the + Work and such Derivative Works in Source or Object form. + + 3. Grant of Patent License. Subject to the terms and conditions of + this License, each Contributor hereby grants to You a perpetual, + worldwide, non-exclusive, no-charge, royalty-free, irrevocable + (except as stated in this section) patent license to make, have made, + use, offer to sell, sell, import, and otherwise transfer the Work, + where such license applies only to those patent claims licensable + by such Contributor that are necessarily infringed by their + Contribution(s) alone or by combination of their Contribution(s) + with the Work to which such Contribution(s) was submitted. If You + institute patent litigation against any entity (including a + cross-claim or counterclaim in a lawsuit) alleging that the Work + or a Contribution incorporated within the Work constitutes direct + or contributory patent infringement, then any patent licenses + granted to You under this License for that Work shall terminate + as of the date such litigation is filed. + + 4. Redistribution. You may reproduce and distribute copies of the + Work or Derivative Works thereof in any medium, with or without + modifications, and in Source or Object form, provided that You + meet the following conditions: + + (a) You must give any other recipients of the Work or + Derivative Works a copy of this License; and + + (b) You must cause any modified files to carry prominent notices + stating that You changed the files; and + + (c) You must retain, in the Source form of any Derivative Works + that You distribute, all copyright, patent, trademark, and + attribution notices from the Source form of the Work, + excluding those notices that do not pertain to any part of + the Derivative Works; and + + (d) If the Work includes a "NOTICE" text file as part of its + distribution, then any Derivative Works that You distribute must + include a readable copy of the attribution notices contained + within such NOTICE file, excluding those notices that do not + pertain to any part of the Derivative Works, in at least one + of the following places: within a NOTICE text file distributed + as part of the Derivative Works; within the Source form or + documentation, if provided along with the Derivative Works; or, + within a display generated by the Derivative Works, if and + wherever such third-party notices normally appear. The contents + of the NOTICE file are for informational purposes only and + do not modify the License. You may add Your own attribution + notices within Derivative Works that You distribute, alongside + or as an addendum to the NOTICE text from the Work, provided + that such additional attribution notices cannot be construed + as modifying the License. + + You may add Your own copyright statement to Your modifications and + may provide additional or different license terms and conditions + for use, reproduction, or distribution of Your modifications, or + for any such Derivative Works as a whole, provided Your use, + reproduction, and distribution of the Work otherwise complies with + the conditions stated in this License. + + 5. Submission of Contributions. Unless You explicitly state otherwise, + any Contribution intentionally submitted for inclusion in the Work + by You to the Licensor shall be under the terms and conditions of + this License, without any additional terms or conditions. + Notwithstanding the above, nothing herein shall supersede or modify + the terms of any separate license agreement you may have executed + with Licensor regarding such Contributions. + + 6. Trademarks. This License does not grant permission to use the trade + names, trademarks, service marks, or product names of the Licensor, + except as required for reasonable and customary use in describing the + origin of the Work and reproducing the content of the NOTICE file. + + 7. Disclaimer of Warranty. Unless required by applicable law or + agreed to in writing, Licensor provides the Work (and each + Contributor provides its Contributions) on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or + implied, including, without limitation, any warranties or conditions + of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A + PARTICULAR PURPOSE. You are solely responsible for determining the + appropriateness of using or redistributing the Work and assume any + risks associated with Your exercise of permissions under this License. + + 8. Limitation of Liability. In no event and under no legal theory, + whether in tort (including negligence), contract, or otherwise, + unless required by applicable law (such as deliberate and grossly + negligent acts) or agreed to in writing, shall any Contributor be + liable to You for damages, including any direct, indirect, special, + incidental, or consequential damages of any character arising as a + result of this License or out of the use or inability to use the + Work (including but not limited to damages for loss of goodwill, + work stoppage, computer failure or malfunction, or any and all + other commercial damages or losses), even if such Contributor + has been advised of the possibility of such damages. + + 9. Accepting Warranty or Additional Liability. While redistributing + the Work or Derivative Works thereof, You may choose to offer, + and charge a fee for, acceptance of support, warranty, indemnity, + or other liability obligations and/or rights consistent with this + License. However, in accepting such obligations, You may act only + on Your own behalf and on Your sole responsibility, not on behalf + of any other Contributor, and only if You agree to indemnify, + defend, and hold each Contributor harmless for any liability + incurred by, or claims asserted against, such Contributor by reason + of your accepting any such warranty or additional liability. + + END OF TERMS AND CONDITIONS + + APPENDIX: How to apply the Apache License to your work. + + To apply the Apache License to your work, attach the following + boilerplate notice, with the fields enclosed by brackets "[]" + replaced with your own identifying information. (Don't include + the brackets!) The text should be enclosed in the appropriate + comment syntax for the file format. We also recommend that a + file or class name and description of purpose be included on the + same "printed page" as the copyright notice for easier + identification within third-party archives. + + Copyright [yyyy] [name of copyright owner] + + Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. + + + diff --git a/packaging/smartcard-plugin-nfc.spec b/packaging/smartcard-plugin-nfc.spec index 4e30737..906bed8 100755 --- a/packaging/smartcard-plugin-nfc.spec +++ b/packaging/smartcard-plugin-nfc.spec @@ -1,38 +1,43 @@ -Name: smartcard-plugin-nfc -Summary: Smartcard plugin nfc -Version: 0.0.1 -Release: 4 -Group: libs -License: Samsung Proprietary License -Source0: %{name}-%{version}.tar.gz -BuildRequires: pkgconfig(glib-2.0) -BuildRequires: pkgconfig(dlog) -BuildRequires: pkgconfig(nfc) -BuildRequires: pkgconfig(nfc-common-lib) -BuildRequires: pkgconfig(smartcard-service) -BuildRequires: pkgconfig(smartcard-service-common) -BuildRequires: cmake -BuildRequires: gettext-tools +Name: smartcard-plugin-nfc +Summary: Smartcard plugin nfc +Version: 0.0.12 +Release: 0 +Group: libs +License: Apache License, Version 2.0 +Source0: %{name}-%{version}.tar.gz +BuildRequires: cmake +BuildRequires: pkgconfig(glib-2.0) +BuildRequires: pkgconfig(dlog) +BuildRequires: pkgconfig(smartcard-service-common) +BuildRequires: pkgconfig(capi-network-nfc) Requires(post): /sbin/ldconfig -Requires(post): /usr/bin/vconftool -requires(postun): /sbin/ldconfig +Requires(postun): /sbin/ldconfig + + %description Smartcard Service plugin nfc + %prep %setup -q %package devel -Summary: smartcard service +Summary: smartcard service nfc Group: Development/Libraries Requires: %{name} = %{version}-%{release} + %description devel smartcard service. %build +%if 0%{?sec_build_binary_debug_enable} +export CFLAGS="$CFLAGS -DTIZEN_DEBUG_ENABLE" +export CXXFLAGS="$CXXFLAGS -DTIZEN_DEBUG_ENABLE" +export FFLAGS="$FFLAGS -DTIZEN_DEBUG_ENABLE" +%endif mkdir obj-arm-limux-qnueabi cd obj-arm-limux-qnueabi cmake .. -DCMAKE_INSTALL_PREFIX=%{_prefix} @@ -42,6 +47,9 @@ cmake .. -DCMAKE_INSTALL_PREFIX=%{_prefix} %install cd obj-arm-limux-qnueabi %make_install +mkdir -p %{buildroot}/usr/share/license +cp -af %{_builddir}/%{name}-%{version}/packaging/%{name} %{buildroot}/usr/share/license/ + %post /sbin/ldconfig @@ -50,14 +58,9 @@ cd obj-arm-limux-qnueabi %postun /sbin/ldconfig -#%post -# -n nfc-common-lib -p /sbin/ldconfig - -#%postun -# -n nfc-common-lib -p /sbin/ldconfig %files +%manifest %{name}.manifest %defattr(-,root,root,-) -/usr/lib/se/lib*.so - - +%{_libdir}/se/lib*.so +%{_datadir}/license/%{name} diff --git a/smartcard-plugin-nfc.manifest b/smartcard-plugin-nfc.manifest new file mode 100644 index 0000000..ca37499 --- /dev/null +++ b/smartcard-plugin-nfc.manifest @@ -0,0 +1,6 @@ + + + + + + -- 2.7.4