tizen 2.3 release tizen_2.3 submit/tizen_2.3/20150202.063344 tizen_2.3_release
authorjk7744.park <jk7744.park@samsung.com>
Sat, 31 Jan 2015 07:39:49 +0000 (16:39 +0900)
committerjk7744.park <jk7744.park@samsung.com>
Sat, 31 Jan 2015 07:39:49 +0000 (16:39 +0900)
CMakeLists.txt [new file with mode: 0755]
LICENSE.APLv2 [new file with mode: 0644]
NOTICE [new file with mode: 0755]
account-parser.manifest [new file with mode: 0644]
account-parser.pc.in [new file with mode: 0755]
packaging/account-parser.spec [new file with mode: 0644]
src/account-dlog.h [new file with mode: 0755]
src/account.c [new file with mode: 0755]

diff --git a/CMakeLists.txt b/CMakeLists.txt
new file mode 100755 (executable)
index 0000000..57fc332
--- /dev/null
@@ -0,0 +1,41 @@
+CMAKE_MINIMUM_REQUIRED(VERSION 2.6)
+PROJECT(account C)
+
+INCLUDE(FindPkgConfig)
+pkg_check_modules(account_pkgs REQUIRED
+       dlog
+       libxml-2.0
+       pkgmgr-info
+       glib-2.0
+       accounts-svc
+       capi-appfw-app-manager
+)
+
+FOREACH(flag ${account_pkgs_CFLAGS})
+       SET(EXTRA_CFLAGS "${EXTRA_CFLAGS} ${flag}")
+ENDFOREACH(flag)
+
+SET (SRCS
+       src/account.c
+)
+
+SET(EXTRA_CFLAGS  "${EXTRA_CFLAGS} -Wall" )
+SET(extapi "-fvisibility=hidden")
+
+## SET C COMPILER FLAGS
+SET(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} ${EXTRA_CFLAGS} ${extapi}")
+
+## SET CPP COMPILER FLAGS
+#SET(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -fvisibility=hidden")
+#SET(CMAKE_CXX_FLAGS "${OSP_DEBUG_FLAGS} ${OSP_OPT_FLAGS} ${CMAKE_CXX_FLAGS} ${EXTRA_CFLAGS} ${OSP_COMPILER_FLAGS}")
+
+## SET LINKER FLAGS
+SET(CMAKE_SHARED_LINKER_FLAGS "-Wl,--as-needed")
+
+## Create Library
+ADD_LIBRARY (${PROJECT_NAME} SHARED ${SRCS})
+TARGET_LINK_LIBRARIES(${PROJECT_NAME} ${account_pkgs_LDFLAGS} )
+
+#CONFIGURE_FILE(account-parser.pc.in ${CMAKE_SOURCE_DIR}/account-parser.pc @ONLY)
+#INSTALL(FILES ${CMAKE_SOURCE_DIR}/account-parser.pc DESTINATION lib/pkgconfig)
+INSTALL(TARGETS ${PROJECT_NAME} DESTINATION "etc/package-manager/parserlib")
diff --git a/LICENSE.APLv2 b/LICENSE.APLv2
new file mode 100644 (file)
index 0000000..d645695
--- /dev/null
@@ -0,0 +1,202 @@
+
+                                 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/NOTICE b/NOTICE
new file mode 100755 (executable)
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/account-parser.manifest b/account-parser.manifest
new file mode 100644 (file)
index 0000000..97e8c31
--- /dev/null
@@ -0,0 +1,5 @@
+<manifest>
+       <request>
+               <domain name="_"/>
+       </request>
+</manifest>
diff --git a/account-parser.pc.in b/account-parser.pc.in
new file mode 100755 (executable)
index 0000000..e44d772
--- /dev/null
@@ -0,0 +1,14 @@
+# Package Information for pkg-config
+
+prefix=@PREFIX@
+exec_prefix=/usr
+libdir=/usr/etc/package-manager/parserlib
+includedir=
+
+Name: @PC_NAME@
+Description: @PACKAGE_DESCRIPTION@
+Version: @VERSION@
+Requires: @PC_REQUIRED@
+Libs: -L${libdir} @PC_LDFLAGS@
+Cflags: -I${includedir}
+
diff --git a/packaging/account-parser.spec b/packaging/account-parser.spec
new file mode 100644 (file)
index 0000000..a1129a7
--- /dev/null
@@ -0,0 +1,53 @@
+Name:          account-parser
+Summary:       account parser library
+Version:       0.0.11
+Release:       0
+Group:         TO_BE/FILLED_IN
+License:       Apache License, Version 2.0
+Source0:       %{name}-%{version}.tar.gz
+BuildRequires:  cmake
+BuildRequires:  pkgconfig(accounts-svc)
+BuildRequires:  pkgconfig(dlog)
+BuildRequires:  pkgconfig(libxml-2.0)
+BuildRequires:  pkgconfig(glib-2.0)
+BuildRequires:  pkgconfig(pkgmgr)
+BuildRequires:  pkgconfig(pkgmgr-info)
+BuildRequires:  pkgconfig(capi-appfw-app-manager)
+
+%description
+account parser library
+
+%prep
+%setup -q
+
+%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
+MAJORVER=`echo %{version} | awk 'BEGIN {FS="."}{print $1}'`
+%ifarch %{ix86}
+CXXFLAGS="$CXXFLAGS -D_OSP_DEBUG_ -D_SECURE_LOG -D_OSP_X86_ -D_OSP_EMUL_" cmake . -DCMAKE_INSTALL_PREFIX=%{_prefix} -DFULLVER=%{version} -DMAJORVER=${MAJORVER}
+%else
+CXXFLAGS="-O2 -g -pipe -Wall -fno-exceptions -Wformat -Wformat-security -Wl,--as-needed -fmessage-length=0 -march=armv7-a -mtune=cortex-a8 -mlittle-endian -mfpu=neon -mfloat-abi=softfp -D__SOFTFP__ -mthumb -Wa,-mimplicit-it=thumb -funwind-tables -D_OSP_DEBUG_ -D_SECURE_LOG -D_OSP_ARMEL_" cmake . -DCMAKE_INSTALL_PREFIX=%{_prefix} -DFULLVER=%{version} -DMAJORVER=${MAJORVER}
+%endif
+
+# Call make instruction with smp support
+make %{?jobs:-j%jobs}
+
+%install
+rm -rf %{buildroot}
+mkdir -p %{buildroot}/usr/share/license
+cp %{_builddir}/%{name}-%{version}/LICENSE.APLv2  %{buildroot}/usr/share/license/%{name}
+
+%make_install
+
+%post -p /sbin/ldconfig
+
+%postun -p /sbin/ldconfig
+
+%files
+%manifest account-parser.manifest
+/usr/share/license/%{name}
+/usr/etc/package-manager/parserlib/libaccount.so*
diff --git a/src/account-dlog.h b/src/account-dlog.h
new file mode 100755 (executable)
index 0000000..b7a6f80
--- /dev/null
@@ -0,0 +1,67 @@
+//
+// Copyright (c) 2014 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 __ACCOUNT_PARSER_DLOG_H__
+#define __ACCOUNT_PARSER_DLOG_H__
+
+#include <dlog.h>
+
+#define COLOR_GREEN    "\033[0;32m"
+#define COLOR_END              "\033[0;m"
+
+#ifdef LOG_TAG
+#undef LOG_TAG
+#endif
+
+#define LOG_TAG "ACCOUNT_PARSER"
+
+#define _E(fmt, arg...) LOGE("[%s:%d] "fmt,__FUNCTION__,__LINE__,##arg)
+#define _D(fmt, arg...) LOGD("[%s:%d] "fmt,__FUNCTION__,__LINE__,##arg)
+#define _SECURE_E(fmt, arg...) SECURE_LOGE("[%s:%d] "fmt,__FUNCTION__,__LINE__,##arg)
+#define _SECURE_D(fmt, arg...) SECURE_LOGD("[%s:%d] "fmt,__FUNCTION__,__LINE__,##arg)
+#define ENTER() LOGD(COLOR_GREEN"BEGIN >>>"COLOR_END);
+
+#define retvm_if(expr, val, fmt, arg...) do { \
+       if(expr) { \
+               _E(fmt, ##arg); \
+               _E("(%s) -> %s() return", #expr, __FUNCTION__); \
+               return (val); \
+       } \
+} while (0)
+
+#define retv_if(expr, val) do { \
+       if(expr) { \
+               _E("(%s) -> %s() return", #expr, __FUNCTION__); \
+               return (val); \
+       } \
+} while (0)
+
+#define retm_if(expr, fmt, arg...) do { \
+       if(expr) { \
+               _E(fmt, ##arg); \
+               _E("(%s) -> %s() return", #expr, __FUNCTION__); \
+               return; \
+       } \
+} while (0)
+
+#define ret_if(expr) do { \
+       if(expr) { \
+               _E("(%s) -> %s() return", #expr, __FUNCTION__); \
+               return; \
+       } \
+} while (0)
+
+#endif                         /* __ACCOUNT_PARSER_DLOG_H__ */
diff --git a/src/account.c b/src/account.c
new file mode 100755 (executable)
index 0000000..ee42d6e
--- /dev/null
@@ -0,0 +1,618 @@
+//
+// Copyright (c) 2014 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.
+//
+
+#include <glib.h>
+#include <dlog.h>
+#include <errno.h>
+#include <libxml/parser.h>
+#include <libxml/tree.h>
+#include <account.h>
+#include <account-types.h>
+#include <pkgmgr-info.h>
+#include <app_manager.h>
+
+#include "account-dlog.h"
+
+/* Define EXPORT_API */
+#ifndef EXPORT_API
+#define EXPORT_API __attribute__((visibility("default")))
+#endif
+
+
+static const xmlChar _NODE_ACCOUNT_PROVIDER[]                          = "account-provider";
+static const xmlChar _NODE_ICON[]                                                      = "icon";
+static const xmlChar _NODE_LABEL[]                                                     = "label";
+static const xmlChar _NODE_CAPABILITY[]                                                = "capability";
+
+static const xmlChar _ATTRIBUTE_APP_ID[]                                       = "appid";
+static const xmlChar _ATTRIBUTE_MULTIPLE_ACCOUNTS_SUPPORT[]    = "multiple-accounts-support";
+static const xmlChar _ATTRIBUTE_SECTION[]                                      = "section";
+static const xmlChar _ATTRIBUTE_TYPE[]                                         = "type";
+static const xmlChar _ATTRIBUTE_XML_LANG[]                                     = "xml:lang";
+
+static const xmlChar _VALUE_TRUE[]                                                     = "true";
+static const xmlChar _VALUE_ACCOUNT[]                                          = "account";
+static const xmlChar _VALUE_ACCOUNT_SMALL[]                                    = "account-small";
+static const xmlChar _VALUE_XHIGH[]                                                    = "Xhigh";
+
+static const char _DEFAULT_LOCALE[]                                                    = "default";
+
+static char __old_account_provider_app_id[1024];
+
+bool _on_account_received_cb(account_h account, void* user_data)
+{
+       ENTER();
+       retvm_if((account == NULL) || (user_data == NULL), false, "A system error has occurred.");
+
+       char* account_provider_app_id = (char*)user_data;
+       retvm_if(account_provider_app_id == NULL, false, "account_provider_app_id is NULL.");
+
+       // Get the account ID
+       int account_db_id = 0;
+       int ret = account_get_account_id(account, &account_db_id);
+       retvm_if(ret != ACCOUNT_ERROR_NONE, false, "[%d] Failed to perform account_get_account_id().", ret);
+
+       ret = account_set_package_name(account, account_provider_app_id);
+       retvm_if(ret != ACCOUNT_ERROR_NONE, false, "[%d] Failed  to perform account_set_package_name().", ret);
+
+       // Update the account
+       ret = account_update_to_db_by_id_ex(account, account_db_id);
+       retvm_if(ret == ACCOUNT_ERROR_NOT_REGISTERED_PROVIDER, false, "[%d] The application does not register the account provider.", ret);
+       retvm_if(ret == ACCOUNT_ERROR_PERMISSION_DENIED, false, "[%d] The application has no permission to update this account.", ret);
+       retvm_if(ret == ACCOUNT_ERROR_RECORD_NOT_FOUND, false, "[%d] The account does not exist.", ret);
+       retvm_if(ret != ACCOUNT_ERROR_NONE, false, "[%d] Failed to perform account_update_to_db_by_id_ex().", ret);
+
+       return true;
+}
+
+int _register_account_provider(xmlDocPtr docPtr, char* account_provider_app_id)
+{
+       ENTER();
+       _D("Registering the Account Provider.");
+
+       int ret = account_connect();
+       retvm_if(ret != ACCOUNT_ERROR_NONE, ret, "[%d]A system error has occurred.", ret);
+
+       int ret2 = 0;
+
+       account_type_h account_type_handle = NULL;
+       ret = account_type_create(&account_type_handle);
+       if(ret != ACCOUNT_ERROR_NONE || account_type_handle == NULL) {
+               _E("[%d]Memory allocation failed.", ret);
+               return ret;
+       }
+
+       // Node: <account>
+       xmlNodePtr cur_ptr = xmlFirstElementChild(xmlDocGetRootElement(docPtr));
+       if(cur_ptr == NULL) {
+               ret = -1;
+               _E("Failed to get the element.");
+               goto CATCH;
+       }
+
+       _SECURE_D("Node: %s", cur_ptr->name);
+
+       // Get the children nodes
+       cur_ptr = cur_ptr->xmlChildrenNode;
+       if(cur_ptr == NULL) {
+               ret = -1;
+               _E("Failed to get the child element.");
+               goto CATCH;
+       }
+
+       while(cur_ptr != NULL) {
+               _SECURE_D("Node: %s", cur_ptr->name);
+
+               // Node: <account-provider>
+               if((!xmlStrcmp(cur_ptr->name, _NODE_ACCOUNT_PROVIDER))) {
+                       // Attribute: appid
+                       xmlChar* attribute_app_id = xmlGetProp(cur_ptr, _ATTRIBUTE_APP_ID);
+                       if(attribute_app_id == NULL) {
+                               ret = -1;
+                               _E("Failed to get the attribute.");
+                               goto CATCH;
+                       }
+
+                       _SECURE_D("Attribute: appid - %s", attribute_app_id);
+
+                       ret = account_type_set_app_id(account_type_handle, (char*)attribute_app_id);
+                       if(ret != ACCOUNT_ERROR_NONE) {
+                               _E("Failed to set the app ID.");
+                               goto CATCH;
+                       }
+
+                       // Attribute: multiple-accounts-support
+                       xmlChar* multiple_accounts_support = xmlGetProp(cur_ptr, _ATTRIBUTE_MULTIPLE_ACCOUNTS_SUPPORT);
+                       if(multiple_accounts_support == NULL) {
+                               ret = -1;
+                               _E("Failed to get the attribute.");
+                               goto CATCH;
+                       }
+
+                       _SECURE_D("Attribute: multiple-accounts-support - %s", multiple_accounts_support);
+
+                       if((!xmlStrcmp(multiple_accounts_support, _VALUE_TRUE))) {
+                               ret = account_type_set_multiple_account_support(account_type_handle, true);
+                               if(ret != ACCOUNT_ERROR_NONE) {
+                                       _E("Failed to set the multiple accounts support.");
+                                       goto CATCH;
+                               }
+                       } else {
+                               ret = account_type_set_multiple_account_support(account_type_handle, false);
+                               if (ret != ACCOUNT_ERROR_NONE)
+                               {
+                                       _E("Failed to set the multiple accounts support.");
+                                       goto CATCH;
+                               }
+                       }
+
+                       // Get the children nodes
+                       cur_ptr = cur_ptr->xmlChildrenNode;
+                       if(cur_ptr == NULL) {
+                               ret = -1;
+                               _E("Failed to get the child element.");
+                               goto CATCH;
+                       }
+
+                       while(cur_ptr != NULL) {
+                               _SECURE_D("Node: %s", cur_ptr->name);
+
+                               // Node: <icon>
+                               if((!xmlStrcmp(cur_ptr->name, _NODE_ICON))) {
+                                       // Attribute: section
+                                       xmlChar* section = xmlGetProp(cur_ptr, _ATTRIBUTE_SECTION);
+                                       if(section == NULL) {
+                                               ret = -1;
+                                               _E("Failed to get the attribute.");
+                                               goto CATCH;
+                                       }
+
+                                       _SECURE_D("Attribute: section - %s", section);
+
+                                       char *resource_path = NULL;
+                                       if((!xmlStrcmp(section, _VALUE_ACCOUNT))) {
+                                               xmlChar* account_icon = xmlNodeListGetString(docPtr, cur_ptr->xmlChildrenNode, 1);
+                                               if(account_icon == NULL) {
+                                                       ret = -1;
+                                                       _E("Failed to get the value.");
+                                                       goto CATCH;
+                                               }
+
+                                               _SECURE_D("Node: icon - %s", account_icon);
+
+                                               if (!strncmp(account_icon, "/usr/share/icons", 16)) {
+                                                       ret = account_type_set_icon_path(account_type_handle, (char*)account_icon);
+                                                       if(ret != ACCOUNT_ERROR_NONE) {
+                                                               _E("Failed to set the icon path.");
+                                                               goto CATCH;
+                                                       }
+                                               } else {
+                                                       if (!strcmp(attribute_app_id, "com.samsung.samsungaccount")) {
+                                                               char *icon_path = g_strdup_printf("%s%s", "/usr/apps/com.samsung.samsungaccount/shared/res/", (char*)account_icon);
+                                                               if(icon_path == NULL) {
+                                                                       _E("icon_path is NULL.");
+                                                                       free(resource_path);
+                                                                       goto CATCH;
+                                                               }
+
+                                                               _D("icon_path[%s]", icon_path);
+                                                               ret = account_type_set_icon_path(account_type_handle, icon_path);
+                                                               if(ret != ACCOUNT_ERROR_NONE) {
+                                                                       _E("Failed to set the icon path.");
+                                                                       g_free(icon_path);
+                                                                       goto CATCH;
+                                                               }
+                                                               g_free(icon_path);
+                                                       } else if (!strcmp(attribute_app_id, "com.samsung.tizenaccount")) {
+                                                               char *icon_path = g_strdup_printf("%s%s", "/usr/apps/com.samsung.tizenaccount/shared/res/", (char*)account_icon);
+                                                               if(icon_path == NULL) {
+                                                                       _E("icon_path is NULL.");
+                                                                       free(resource_path);
+                                                                       goto CATCH;
+                                                               }
+
+                                                               _D("icon_path[%s]", icon_path);
+                                                               ret = account_type_set_icon_path(account_type_handle, icon_path);
+                                                               if(ret != ACCOUNT_ERROR_NONE) {
+                                                                       _E("Failed to set the icon path.");
+                                                                       g_free(icon_path);
+                                                                       goto CATCH;
+                                                               }
+                                                               g_free(icon_path);
+                                                       } else {
+                                                               ret = app_manager_get_shared_resource_path((char*)attribute_app_id, &resource_path);
+                                                               if(ret != APP_MANAGER_ERROR_NONE) {
+                                                                       _E("Failed to get the shared resource path.");
+                                                                       goto CATCH;
+                                                               }
+
+                                                               char *icon_path = g_strdup_printf("%s%s", resource_path, (char*)account_icon);
+                                                               if(icon_path == NULL) {
+                                                                       _E("icon_path is NULL.");
+                                                                       free(resource_path);
+                                                                       goto CATCH;
+                                                               }
+
+                                                               free(resource_path);
+
+                                                               _D("icon_path[%s]", icon_path);
+                                                               ret = account_type_set_icon_path(account_type_handle, icon_path);
+                                                               if(ret != ACCOUNT_ERROR_NONE) {
+                                                                       _E("Failed to set the icon path.");
+                                                                       g_free(icon_path);
+                                                                       goto CATCH;
+                                                               }
+                                                               g_free(icon_path);
+                                                       }
+                                               }
+                                       } else if((!xmlStrcmp(section, _VALUE_ACCOUNT_SMALL))) {
+                                               xmlChar* account_small_icon = xmlNodeListGetString(docPtr, cur_ptr->xmlChildrenNode, 1);
+                                               if(account_small_icon == NULL) {
+                                                       ret = -1;
+                                                       _E("Failed to get the value.");
+                                                       goto CATCH;
+                                               }
+
+                                               _SECURE_D("Node: icon (small) - %s",  account_small_icon);
+
+                                               if (!strncmp(account_small_icon, "/usr/share/icons", 16) || !strcmp(account_small_icon, "/usr/apps/com.samsung.tizenaccount/shared/res/TizenAccount.png")) {
+                                                       ret = account_type_set_small_icon_path(account_type_handle, (char*)account_small_icon);
+                                                       if(ret != ACCOUNT_ERROR_NONE) {
+                                                               _E("Failed to set the small icon path.");
+                                                               goto CATCH;
+                                                       }
+                                               } else {
+                                                       if (!strcmp(attribute_app_id, "com.samsung.samsungaccount")) {
+                                                               char *small_icon_path = g_strdup_printf("%s%s", "/usr/apps/com.samsung.samsungaccount/shared/res/", (char*)account_small_icon);
+                                                               if(small_icon_path == NULL) {
+                                                                       _E("small_icon_path is NULL.");
+                                                                       free(resource_path);
+                                                                       goto CATCH;
+                                                               }
+
+                                                               _D("small_icon_path[%s]", small_icon_path);
+                                                               ret = account_type_set_small_icon_path(account_type_handle, (char*)small_icon_path);
+                                                               if(ret != ACCOUNT_ERROR_NONE) {
+                                                                       _E("Failed to set the small icon path.");
+                                                                       g_free(small_icon_path);
+                                                                       goto CATCH;
+                                                               }
+                                                               g_free(small_icon_path);
+                                                       } else {
+                                                               ret = app_manager_get_shared_resource_path((char*)attribute_app_id, &resource_path);
+                                                               if(ret != APP_MANAGER_ERROR_NONE) {
+                                                                       _E("Failed to get the shared resource path.");
+                                                                       goto CATCH;
+                                                               }
+
+                                                               char *small_icon_path = g_strdup_printf("%s%s", resource_path, (char*)account_small_icon);
+                                                               if(small_icon_path == NULL) {
+                                                                       _E("small_icon_path is NULL.");
+                                                                       free(resource_path);
+                                                                       goto CATCH;
+                                                               }
+
+                                                               free(resource_path);
+
+                                                               _D("small_icon_path[%s]", small_icon_path);
+                                                               ret = account_type_set_small_icon_path(account_type_handle, (char*)small_icon_path);
+                                                               if(ret != ACCOUNT_ERROR_NONE) {
+                                                                       _E("Failed to set the small icon path.");
+                                                                       g_free(small_icon_path);
+                                                                       goto CATCH;
+                                                               }
+                                                               g_free(small_icon_path);
+                                                       }
+                                               }
+                                       }
+                               } else if((!xmlStrcmp(cur_ptr->name, _NODE_LABEL))) {
+                                       // Node: <label>
+
+                                       _SECURE_D("Node: %s", cur_ptr->name);
+
+                               // Attribute: xml:lang
+                                       xmlChar* xml_lang = xmlNodeGetLang(cur_ptr);
+                                       if(xml_lang != NULL) {
+                                               _SECURE_D("Attribute: xml:lang - %s", xml_lang);
+
+                                               char* lang = (char*)xml_lang;
+                                               char* converted_lang = NULL;
+
+                                               gchar** tokens = g_strsplit(lang, "-", 2);
+                                               if(tokens == NULL) {
+                                                       ret = -1;
+                                                       _E("Failed to get token.");
+                                                       goto CATCH;
+                                               }
+
+                                               char* upper_token = g_ascii_strup(tokens[1], strlen(tokens[1]));
+                                               if(upper_token == NULL) {
+                                                       ret = -1;
+                                                       g_strfreev(tokens);
+                                                       _E("Failed to convert to upper case.");
+                                                       goto CATCH;
+                                               }
+
+                                               converted_lang = g_strdup_printf("%s_%s", tokens[0], upper_token);
+                                               free(upper_token);
+
+                                               if(converted_lang == NULL) {
+                                                       ret = -1;
+                                                       g_strfreev(tokens);
+                                                       _E("Failed to convert to upper case.");
+                                                       goto CATCH;
+                                               }
+
+                                               _SECURE_D("Attribute: converted lang - %s", converted_lang);
+
+                                               g_strfreev(tokens);
+
+                                               xmlChar* xml_label = xmlNodeListGetString(docPtr, cur_ptr->xmlChildrenNode, 1);
+                                               if(xml_label == NULL) {
+                                                       ret = -1;
+                                                       g_free(converted_lang);
+                                                       _E("Failed to get the value.");
+                                                       goto CATCH;
+                                               }
+
+                                               _SECURE_D("Node: label - %s", xml_label);
+
+                                               ret = account_type_set_label(account_type_handle, (char*)xml_label, converted_lang);
+                                               if(ret != ACCOUNT_ERROR_NONE) {
+                                                       g_free(converted_lang);
+                                                       _E("[%d]Failed to set the display name.", ret);
+                                                       goto CATCH;
+                                               }
+
+                                               g_free(converted_lang);
+                                       } else {
+                                               xmlChar* xml_label = xmlNodeListGetString(docPtr, cur_ptr->xmlChildrenNode, 1);
+                                               if(xml_label == NULL) {
+                                                       ret = -1;
+                                                       _E("Failed to get the value.");
+                                                       goto CATCH;
+                                               }
+
+                                               _SECURE_D("Node: label - %s",  xml_label);
+
+                                               ret = account_type_set_label(account_type_handle, (char*)xml_label, _DEFAULT_LOCALE);
+                                               if(ret != ACCOUNT_ERROR_NONE) {
+                                                       _E("[%d]Failed to set the display name.", ret);
+                                                       goto CATCH;
+                                               }
+                                       }
+                               } else if((!xmlStrcmp(cur_ptr->name, _NODE_CAPABILITY))) {
+                                       // Node: <capability>
+
+                                       _SECURE_D("Node: %s", cur_ptr->name);
+
+                                       xmlChar* xml_capability = xmlNodeListGetString(docPtr, cur_ptr->xmlChildrenNode, 1);
+                                       if(xml_capability == NULL) {
+                                               ret = -1;
+                                               _E("Failed to get the value.");
+                                               goto CATCH;
+                                       }
+
+                                       _SECURE_D("Node: capability - %s",  xml_capability);
+
+                                       ret = account_type_set_provider_feature(account_type_handle, (char*)xml_capability);
+                                       if(ret != ACCOUNT_ERROR_NONE) {
+                                               _E("[%d]Failed to set the capability.", ret);
+                                               goto CATCH;
+                                       }
+                               }
+
+                               cur_ptr = cur_ptr->next;
+                       }
+
+                       break;
+               }
+
+               cur_ptr = cur_ptr->next;
+       }
+
+       // Insert the account type to the account DB
+       {
+               int account_type_db_id = 0;
+               ret = account_type_insert_to_db(account_type_handle, &account_type_db_id);
+               if(ret != ACCOUNT_ERROR_NONE) {
+                       _E("[%d]Failed to perform account_type_insert_to_db().", ret);
+                       goto CATCH;
+               }
+       }
+
+       ret = account_type_destroy(account_type_handle);
+       if(ret != ACCOUNT_ERROR_NONE) {
+               _E("[%d]Failed to perform account_type_destroy().", ret);
+               goto CATCH;
+       }
+
+       ret = account_disconnect();
+       if(ret != ACCOUNT_ERROR_NONE) {
+               _E("[%d]Failed to perform account_disconnect().", ret);
+               goto CATCH;
+       }
+
+       return 0;
+
+CATCH:
+       ret2 = account_type_destroy(account_type_handle);
+       retvm_if(ret2 != ACCOUNT_ERROR_NONE, ret2, "[%d]Failed to perform account_type_destroy().", ret2);
+
+       ret2 = account_disconnect();
+       retvm_if(ret2 != ACCOUNT_ERROR_NONE, ret2, "[%d]Failed to perform account_disconnect().", ret2);
+
+       return ret;
+}
+
+int _unregister_account_provider(pkgmgrinfo_appinfo_h package_info_handle, void* user_data)
+{
+       ENTER();
+       _D("Unregistering the Account Provider.");
+
+       char* app_id = NULL;
+       pkgmgrinfo_appinfo_get_appid(package_info_handle, &app_id);
+       _D("appid : %s", app_id);
+
+       int ret = account_connect();
+       retvm_if(ret != ACCOUNT_ERROR_NONE, ret, "[%d]Failed to account_connect().", ret);
+
+       int ret2 = 0;
+
+       ret = account_delete_from_db_by_package_name((char*)app_id);
+       if((ret != ACCOUNT_ERROR_NONE) && (ret !=  ACCOUNT_ERROR_RECORD_NOT_FOUND)) {
+               _E("Failed to perform account_delete_from_db_by_package_name().");
+               goto CATCH;
+       }
+
+       ret = account_type_delete_by_app_id((char*)app_id);
+       if(ret != ACCOUNT_ERROR_NONE) {
+               _E("Failed to perform account_type_delete_by_app_id().");
+               goto CATCH;
+       }
+
+       ret = account_disconnect();
+       retvm_if(ret != ACCOUNT_ERROR_NONE, ret, "[%d]Failed to account_disconnect().", ret);
+
+       return PMINFO_R_OK;
+
+CATCH:
+       ret2 = account_disconnect();
+       retvm_if(ret2 != ACCOUNT_ERROR_NONE, ret, "[%d]Failed to account_disconnect().", ret2);
+
+       return ret;
+}
+
+int _on_package_app_list_received_cb(pkgmgrinfo_appinfo_h handle, void *user_data)
+{
+       ENTER();
+       _D("Pkgmgr parser plugin pre upgrade.");
+
+       char* app_id = NULL;
+       pkgmgrinfo_appinfo_get_appid(handle, &app_id);
+       _D("appid : %s", app_id);
+
+       int ret = account_connect();
+       retvm_if(ret != ACCOUNT_ERROR_NONE, ret, "[%d]Failed to account_connect().", ret);
+
+       ret = account_type_delete_by_app_id((char*)app_id);
+       if(ret == ACCOUNT_ERROR_NONE) {
+               _D("PKGMGR_PARSER_PLUGIN_PRE_UPGRADE: app ID - %s", app_id);
+               strncpy(__old_account_provider_app_id, app_id, 128);
+
+               return 0;
+       }
+
+       ret = account_disconnect();
+       retvm_if(ret != ACCOUNT_ERROR_NONE, ret, "[%d]Failed to account_disconnect().", ret);
+
+       return 0;
+}
+
+EXPORT_API
+int PKGMGR_PARSER_PLUGIN_INSTALL(xmlDocPtr docPtr, const char* packageId)
+{
+       ENTER();
+       _D("PKGMGR_PARSER_PLUGIN_INSTALL");
+
+       char* account_provider_app_id = NULL;
+       int ret = _register_account_provider(docPtr, account_provider_app_id);
+       retvm_if(ret != 0, -1, "Failed to register the account provider.");
+
+       return 0;
+}
+
+EXPORT_API
+int PKGMGR_PARSER_PLUGIN_UNINSTALL(xmlDocPtr docPtr, const char* packageId)
+{
+       ENTER();
+       _D("PKGMGR_PARSER_PLUGIN_UNINSTALL");
+
+       pkgmgrinfo_pkginfo_h package_info_handle = NULL;
+
+       int ret = pkgmgrinfo_pkginfo_get_pkginfo(packageId, &package_info_handle);
+       retvm_if(ret != PMINFO_R_OK, ret, "[%d]Failed to pkgmgrinfo_pkginfo_get_pkginfo().", ret);
+
+       ret = pkgmgrinfo_appinfo_get_list(package_info_handle, PMINFO_UI_APP, _unregister_account_provider, NULL);
+       if(ret != PMINFO_R_OK) {
+               _D("Failed to get the application information list.");
+               pkgmgrinfo_pkginfo_destroy_pkginfo(package_info_handle);
+
+               return -1;
+       }
+
+       pkgmgrinfo_pkginfo_destroy_pkginfo(package_info_handle);
+       return 0;
+}
+
+EXPORT_API
+int PKGMGR_PARSER_PLUGIN_PRE_UPGRADE(const char* packageId)
+{
+       ENTER();
+       _D("PKGMGR_PARSER_PLUGIN_PRE_UPGRADE");
+
+       memset(__old_account_provider_app_id, 0x00, sizeof(__old_account_provider_app_id));
+
+       pkgmgrinfo_pkginfo_h package_info_handle = NULL;
+
+       int ret = pkgmgrinfo_pkginfo_get_pkginfo(packageId, &package_info_handle);
+       retvm_if(ret != PMINFO_R_OK, ret, "[%d]Failed to pkgmgrinfo_pkginfo_get_pkginfo().", ret);
+
+       ret = pkgmgrinfo_appinfo_get_list(package_info_handle, PMINFO_UI_APP, _on_package_app_list_received_cb, NULL);
+       if(ret != PMINFO_R_OK) {
+               _D("Failed to get the application information list.");
+               pkgmgrinfo_pkginfo_destroy_pkginfo(package_info_handle);
+
+               return -1;
+       }
+
+       pkgmgrinfo_pkginfo_destroy_pkginfo(package_info_handle);
+
+       return 0;
+}
+
+EXPORT_API
+int PKGMGR_PARSER_PLUGIN_UPGRADE(xmlDocPtr docPtr, const char* packageId)
+{
+       ENTER();
+       _D("PKGMGR_PARSER_PLUGIN_UPGRADE");
+
+       char* account_provider_app_id = NULL;
+       int ret = _register_account_provider(docPtr, account_provider_app_id);
+       retvm_if(ret != 0, ret, "[%d]Failed to register the account provider.", ret);
+
+       ret = account_connect();
+       retvm_if(ret != ACCOUNT_ERROR_NONE, ret, "[%d]Failed to perfrom account_connect().", ret);
+
+       int ret2 = 0;
+
+       ret = account_query_account_by_package_name(_on_account_received_cb, __old_account_provider_app_id, (void*)account_provider_app_id);
+       if((ret != ACCOUNT_ERROR_NONE) && (ret != ACCOUNT_ERROR_RECORD_NOT_FOUND)) {
+               _E("Failed to perform account_query_account_by_package_name().");
+               goto CATCH;
+       }
+
+       ret = account_disconnect();
+       retvm_if(ret != ACCOUNT_ERROR_NONE, ret, "[%d]Failed to perfrom account_disconnect().", ret);
+
+       return 0;
+
+CATCH:
+       ret2 = account_disconnect();
+       retvm_if(ret2 != ACCOUNT_ERROR_NONE, ret2, "[%d]Failed to perfrom account_disconnect().", ret2);
+
+       return ret;
+}