From 8b82207e42ef9b04274a48f887e7e5c4333556a0 Mon Sep 17 00:00:00 2001 From: Manasij Sur Roy Date: Wed, 20 Jan 2016 14:29:31 +0530 Subject: [PATCH] Removed Test ASM, Disabled Sample RPM test app Change-Id: I9246a9f4314b7c2302502ecbf64460ab68ea3cab Signed-off-by: Manasij Sur Roy --- CMakeLists.txt | 4 +- packaging/fido-client.spec | 102 +++-------- test/Dummy_ASM_DBUS/CMakeLists.txt | 39 ----- test/Dummy_ASM_DBUS/dummy_asm.json | 8 - test/Dummy_ASM_DBUS/dummy_asm_server.c | 299 --------------------------------- 5 files changed, 30 insertions(+), 422 deletions(-) delete mode 100644 test/Dummy_ASM_DBUS/CMakeLists.txt delete mode 100644 test/Dummy_ASM_DBUS/dummy_asm.json delete mode 100644 test/Dummy_ASM_DBUS/dummy_asm_server.c diff --git a/CMakeLists.txt b/CMakeLists.txt index f3c6fa3..da20447 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -12,6 +12,6 @@ ADD_SUBDIRECTORY(fido_svc_ui) ADD_SUBDIRECTORY(server) ADD_DEPENDENCIES(fido-service fido-ui-service) #INSTALL(DIRECTORY lib/fido/asm/ DESTINATION lib/fido/asm/) -ADD_SUBDIRECTORY(test/Dummy_ASM_DBUS) -ADD_SUBDIRECTORY(test/Fido_Sample_RPM) +##ADD_SUBDIRECTORY(test/Dummy_ASM_DBUS) +##ADD_SUBDIRECTORY(test/Fido_Sample_RPM) ADD_SUBDIRECTORY(test/shell_tc) diff --git a/packaging/fido-client.spec b/packaging/fido-client.spec index 24fd7fc..2e907e8 100644 --- a/packaging/fido-client.spec +++ b/packaging/fido-client.spec @@ -10,9 +10,6 @@ Source1: org.tizen.fido.service Source2: org.tizen.fido.conf Source3: org.tizen.fido.service -Source4: org.tizen.dummyasm.service -Source5: org.tizen.dummyasm.conf - BuildRequires: cmake BuildRequires: pkgconfig(glib-2.0) BuildRequires: pkgconfig(dlog) @@ -84,18 +81,6 @@ mkdir -p %{buildroot}%{_unitdir}/multi-user.target.wants install -m 644 %SOURCE3 %{buildroot}%{_unitdir}/org.tizen.fido.service %install_service multi-user.target.wants org.tizen.fido.service -mkdir -p %{buildroot}/usr/share/dbus-1/system-services -install -m 0644 %SOURCE4 %{buildroot}/usr/share/dbus-1/system-services/org.tizen.dummyasm.service - -mkdir -p %{buildroot}%{_sysconfdir}/dbus-1/system.d -install -m 0644 %{SOURCE5} %{buildroot}%{_sysconfdir}/dbus-1/system.d/ - -mkdir -p %{buildroot}%{_unitdir}/multi-user.target.wants -install -m 644 %SOURCE4 %{buildroot}%{_unitdir}/org.tizen.dummyasm.service -%install_service multi-user.target.wants org.tizen.dummyasm.service - -install -m 0644 test/Dummy_ASM_DBUS/dummy_asm.json %{buildroot}%{_libdir}/fido/asm/dummy_asm.json - %make_install mkdir -p %{buildroot}%{_libdir} @@ -156,65 +141,34 @@ FIDO Service UI ##/usr/apps/org.tizen.fidosvcui/res/* /usr/share/packages/org.tizen.fidosvcui.xml /usr/share/icons/default/small/org.tizen.fidosvcui.png - -################################################################################# -# FIDO Dummy ASM -%package -n dummyasm -Summary: FIDO Dummy ASM (Internal Dev) -Group: Account/Testing - -BuildRequires: cmake -BuildRequires: pkgconfig(capi-appfw-application) -BuildRequires: pkgconfig(capi-system-system-settings) -BuildRequires: pkgconfig(elementary) -BuildRequires: pkgconfig(efl-extension) -BuildRequires: pkgconfig(dlog) -BuildRequires: pkgconfig(json-glib-1.0) -BuildRequires: pkgconfig(glib-2.0) >= 2.26 -BuildRequires: pkgconfig(gio-unix-2.0) -BuildRequires: pkgconfig(libtzplatform-config) -Requires: fido-client - -%description -n dummyasm -This is a dummy ASM. - -%files -n dummyasm -%manifest dummyasm.manifest -%config %{_sysconfdir}/dbus-1/system.d/org.tizen.dummyasm.conf -%{_bindir}/dummyasm-service -%attr(0644,root,root) %{_unitdir}/org.tizen.dummyasm.service -%attr(0644,root,root) %{_unitdir}/multi-user.target.wants/org.tizen.dummyasm.service -%attr(0644,root,root) /usr/share/dbus-1/system-services/org.tizen.dummyasm.service -%{_libdir}/fido/asm/dummy_asm.json - ################################################################################# -# Fido Sample App - -%package -n org.tizen.FidoSample -Summary: Fido Sample App (Internal Dev) -Group: Account/Testing +## Fido Sample App +## +##%package -n org.tizen.FidoSample +##Summary: Fido Sample App (Internal Dev) +##Group: Account/Testing #Requires: %{name} = %{version}-%{release} - -BuildRequires: cmake -BuildRequires: pkgconfig(capi-appfw-application) -BuildRequires: pkgconfig(capi-system-system-settings) -BuildRequires: pkgconfig(elementary) -BuildRequires: pkgconfig(efl-extension) -BuildRequires: pkgconfig(dlog) -BuildRequires: pkgconfig(json-glib-1.0) -BuildRequires: pkgconfig(glib-2.0) >= 2.26 -BuildRequires: pkgconfig(gio-unix-2.0) -Requires: fido-client - -%description -n org.tizen.FidoSample -This is a program to test the Fido service internally. - -%files -n org.tizen.FidoSample -%defattr(-,root,root,-) -/usr/share/license/%{name} -%manifest org.tizen.FidoSample.manifest -/opt/usr/apps/org.tizen.FidoSample/bin/* -/opt/usr/apps/org.tizen.FidoSample/res/* -/opt/usr/apps/org.tizen.FidoSample/shared/res/* -/opt/share/packages/org.tizen.FidoSample.xml +## +##BuildRequires: cmake +##BuildRequires: pkgconfig(capi-appfw-application) +##BuildRequires: pkgconfig(capi-system-system-settings) +##BuildRequires: pkgconfig(elementary) +##BuildRequires: pkgconfig(efl-extension) +##BuildRequires: pkgconfig(dlog) +##BuildRequires: pkgconfig(json-glib-1.0) +##BuildRequires: pkgconfig(glib-2.0) >= 2.26 +##BuildRequires: pkgconfig(gio-unix-2.0) +##Requires: fido-client +## +##%description -n org.tizen.FidoSample +##This is a program to test the Fido service internally. +## +##%files -n org.tizen.FidoSample +##%defattr(-,root,root,-) +##/usr/share/license/%{name} +##%manifest org.tizen.FidoSample.manifest +##/opt/usr/apps/org.tizen.FidoSample/bin/* +##/opt/usr/apps/org.tizen.FidoSample/res/* +##/opt/usr/apps/org.tizen.FidoSample/shared/res/* +##/opt/share/packages/org.tizen.FidoSample.xml ##/opt/share/icons/default/small/org.tizen.FidoSample.png diff --git a/test/Dummy_ASM_DBUS/CMakeLists.txt b/test/Dummy_ASM_DBUS/CMakeLists.txt deleted file mode 100644 index 96a60f8..0000000 --- a/test/Dummy_ASM_DBUS/CMakeLists.txt +++ /dev/null @@ -1,39 +0,0 @@ -SET(ASM_DAEMON dummyasm-service) - -INCLUDE(FindPkgConfig) -pkg_check_modules(ASM_PKGS REQUIRED - dlog - glib-2.0 - gio-unix-2.0 - capi-base-common - vconf - json-glib-1.0 - capi-appfw-application -) - -FOREACH(flag ${ASM_PKGS_CFLAGS}) - SET(EXTRA_CFLAGS "${EXTRA_CFLAGS} ${flag}") -ENDFOREACH(flag) - -INCLUDE_DIRECTORIES(${CMAKE_SOURCE_DIR}/common) - -ADD_CUSTOM_COMMAND( OUTPUT ${CMAKE_SOURCE_DIR}/common/dummy-asm-stub.c ${CMAKE_SOURCE_DIR}/common/dummy-asm-stub.h -WORKING_DIRECTORY ${CMAKE_SOURCE_DIR}/common/ -COMMAND gdbus-codegen --interface-prefix org.tizen. --generate-c-code dummy-asm-stub ${CMAKE_SOURCE_DIR}/common/dbus_interfaces/dummyasm.xml -COMMENT "Generating Dummy ASM GDBus stubs........................") - -SET(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} ${EXTRA_CFLAGS} -Wall -Werror") -SET(CMAKE_LDFLAGS "-Wl,-zdefs") - -SET(DUMMY_ASM_SRCS - dummy_asm_server.c -) - -ADD_EXECUTABLE(${ASM_DAEMON} ${DUMMY_ASM_SRCS} ${CMAKE_SOURCE_DIR}/common/dummy-asm-stub.c) -ADD_DEPENDENCIES(${PROJECT_NAME} ${CMAKE_SOURCE_DIR}/common/dummy-asm-stub.h) -ADD_DEPENDENCIES(${PROJECT_NAME} ${CMAKE_SOURCE_DIR}/common/dummy-asm-stub.c) - -TARGET_LINK_LIBRARIES(${ASM_DAEMON} ${ASM_PKGS_LDFLAGS}) - -INSTALL(TARGETS ${ASM_DAEMON} DESTINATION bin) -INSTALL(FILES ${CMAKE_SOURCE_DIR}/test/Dummy_ASM_DBUS/dummy_asm.json DESTINATION ${LIBDIR}/fido/asm/) diff --git a/test/Dummy_ASM_DBUS/dummy_asm.json b/test/Dummy_ASM_DBUS/dummy_asm.json deleted file mode 100644 index a34e200..0000000 --- a/test/Dummy_ASM_DBUS/dummy_asm.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "vendor" : "Dummy Corp", - "bin_path" : "/usr/bin/dummyasm-service", - "dbus_info" : "org.tizen.dummyasm", - "dbus_obj_path" : "/org/tizen/dummyasm", - "dbus_interface_name" : "org.tizen.dummyasm", - "dbus_method_name" : "asm_request" -} diff --git a/test/Dummy_ASM_DBUS/dummy_asm_server.c b/test/Dummy_ASM_DBUS/dummy_asm_server.c deleted file mode 100644 index 37734d6..0000000 --- a/test/Dummy_ASM_DBUS/dummy_asm_server.c +++ /dev/null @@ -1,299 +0,0 @@ -/* - * Copyright (c) 2014 - 2015 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. - * - */ - -#include -#include -#include -#include -#include -#include -#include -#if !GLIB_CHECK_VERSION (2, 31, 0) -#include -#endif - -#include -#include "fido_internal_types.h" -#include "fido_logs.h" - -#include "dummy-asm-stub.h" - -#define _DUMMY_ASM_SERVICE_DBUS_PATH "/org/tizen/dummyasm" - -#define _GET_INFO_RESPONSE "{\"responseData\":{\"Authenticators\":[{\"aaid\":\"0001#8001\",\"asmVersions\":[{\"major\":1,\"minor\":0}],\"assertionScheme\":\"UAFV1TLV\",\"title\":\"UAF PIN 1\",\"attestationTypes\":[15879],\"tcDisplayContentType\":\"text/plain\",\"description\":\"Pretty long description\",\"supportedExtensionIDs\":[\"abc\"],\"icon\":\"\",\"isRoamingAuthenticator\":false,\"isSecondFactorOnly\":false,\"isUserEnrolled\":true,\"keyProtection\":1,\"matcherProtection\":1,\"hasSettings\":true,\"tcDisplay\":1,\"authenticatorIndex\":1,\"authenticationAlgorithm\":1,\"attachmentHint\":1,\"userVerification\":4},{\"aaid\":\"DDDD#C001\",\"asmVersions\":[{\"major\":1,\"minor\":0}],\"assertionScheme\":\"UAFV1TLV\",\"title\":\"UAF PIN 2\",\"attestationTypes\":[15879],\"tcDisplayContentType\":\"text/plain\",\"description\":\"Pretty long description\",\"supportedExtensionIDs\":[\"abc\"],\"icon\":\"\",\"isRoamingAuthenticator\":false,\"isSecondFactorOnly\":false,\"isUserEnrolled\":true,\"keyProtection\":1,\"matcherProtection\":1,\"hasSettings\":true,\"tcDisplay\":1,\"authenticatorIndex\":2,\"authenticationAlgorithm\":1,\"attachmentHint\":1,\"userVerification\":4}]},\"statusCode\":0}" - -#define _REG_RESPONSE "{\"responseData\":{\"assertion\":\"AT7gAgM-sQALLgkAMDAwMSM4MDAxDi4HAAABAQEAAAEKLiAAbuzkawu9cagRfQWDaOHkQAraLfwuBlCX5WEbQn-2vCQJLiAA1eVp7JIQlwm6YF0YEmGZdNCA27qZoIcZGC0Uaw71bR8NLggAAQAAAAEAAAAMLkEABDvrbVayiXwIsfShzUc2ALT8K3pZKykYGvpD7nU5Jy4sEXEKsepcRfZebCH7RHLwbchz6AmrK-3o1RAbauiuZMcHPicCBi5AAE3tsSOmUITLnQdbRTXdIe2R27E3e3JarZ8MT-9qcZug7__AM5ZUrXqyzSMhRCz9yHEhaeRMyRctxcD18uimqikFLt8BMIIB2zCCAYICCQDDAwxEtwee0TAJBgcqhkjOPQQBMHsxCzAJBgNVBAYTAlVTMQswCQYDVQQIDAJDQTELMAkGA1UEBwwCUEExEDAOBgNVBAoMB05OTCxJbmMxDTALBgNVBAsMBERBTjExEzARBgNVBAMMCk5OTCxJbmMgQ0ExHDAaBgkqhkiG9w0BCQEWDW5ubEBnbWFpbC5jb20wHhcNMTQxMjE4MTYwMzEyWhcNMjQxMjE1MTYwMzEyWjByMQswCQYDVQQGEwJVUzELMAkGA1UECAwCQ0ExEjAQBgNVBAcMCVBhbG8gQWx0bzEbMBkGA1UECgwSTm9rIE5vayBMYWJzLCBJbmMuMSUwIwYJKoZIhvcNAQkBFhZub2tub2tjZXJ0c0Bub2tub2suY29tMFkwEwYHKoZIzj0CAQYIKoZIzj0DAQcDQgAEhNa9EIVUCSqfiALGZXM1Zc32gFJfTpGFHIQD5OciVVs4HAl9o1mQOA9WPKhAWH_2dEubn0fQSi1sq4EaOReesjAJBgcqhkjOPQQBA0gAMEUCIHeQm_CRb_joYNff0v9OIzt3FKHvlCZh6ErUldOqUW-UAiEA2kNe-dEqXki2ikfMq79SO7ernvtSZ8X99PuhmMVjxT0\",\"assertionScheme\":\"UAFV1TLV\"},\"statusCode\":0}" - -#define _AUTH_RESPONSE "{\"responseData\":{\"assertion\":\"Aj7WAAQ-jgALLgkAMDAwMSM4MDAxDi4FAAABAQEADy4gAPyMxESI2aTWj7ETwRifnwh3EBOiZdCJDPeFTZuit-ivCi4gABsFkal_ID2-Q2jC0Mtblw4_ApXVeaogzzD-iE3erYUuEC4AAAkuIADV5WnskhCXCbpgXRgSYZl00IDbupmghxkYLRRrDvVtHw0uBAACAAAABi5AAGewExLjMHW0S6iVoHqGzGS8-qGmLfc35WdBSawTDx0rF7sbXUpQQ9LkK4LM-Fu3YgmpEEBXT254dIXbJzr4_oE\",\"assertionScheme\":\"UAFV1TLV\"},\"statusCode\":0}" - -#define _DEREG_RESPONSE "{\"statusCode\" : 0}" - -#define _GET_REGISTRATIONS_RESPONSE "{\"responseData\":{\"appRegs\":[{\"appID\":\"https://qa-egypt.noknoktest.com:443/UAFSampleProxy/uaf/facets.uaf\",\"keyIDs\":[\"1eVp7JIQlwm6YF0YEmGZdNCA27qZoIcZGC0Uaw71bR8\"]}]},\"statusCode\":0}" - -#define _FREEDESKTOP_SERVICE "org.freedesktop.DBus" -#define _FREEDESKTOP_PATH "/org/freedesktop/DBus" -#define _FREEDESKTOP_INTERFACE "org.freedesktop.DBus" - -#define _FIDO_SERVICE_PATH "/usr/bin/fido-service" - -static guint owner_id = 0; - -static Dummyasm* __dbus_obj = NULL; - -static inline int -__read_proc(const char *path, char *buf, int size) -{ - int fd = 0; - int ret = 0; - - if (buf == NULL || path == NULL) { - _ERR("path and buffer is mandatory\n"); - return -1; - } - - fd = open(path, O_RDONLY); - if (fd < 0) { - _ERR("fd open error(%d)\n", fd); - return -1; - } - - ret = read(fd, buf, size - 1); - if (ret <= 0) { - _ERR("fd read error(%d)\n", fd); - close(fd); - return -1; - } else - buf[ret] = 0; - - close(fd); - - return ret; -} - -static char* -__get_proc_path_of_dbus_caller(GDBusMethodInvocation *invocation) -{ - //pid_t remote_pid = 0; - GError *error = NULL; - GDBusConnection *connection = NULL; - GVariant *response = NULL; - guint32 upid; - const gchar *sender = NULL; - - sender = g_dbus_method_invocation_get_sender (invocation); - if (!sender) { - _ERR("Failed to get sender"); - return NULL; - } - - connection = g_dbus_method_invocation_get_connection(invocation); - if (connection == NULL) { - _ERR("Failed to open connection for the invocation [%s]", error->message); - g_error_free (error); - return NULL; - } - - error = NULL; - response = g_dbus_connection_call_sync (connection, - _FREEDESKTOP_SERVICE, _FREEDESKTOP_PATH, - _FREEDESKTOP_INTERFACE, "GetConnectionUnixProcessID", - g_variant_new ("(s)", sender), ((const GVariantType *) "(u)"), - G_DBUS_CALL_FLAGS_NONE, -1, NULL, &error); - - if (response == NULL) { - _ERR("Failed to get caller id [%s]", error->message); - g_error_free (error); - return NULL; - } - - g_variant_get (response, "(u)", &upid); - _INFO("Remote msg-bus peer service=%s pid=%u", sender, upid); - //remote_pid = (pid_t) upid; - - g_variant_unref (response); - - char buf[128]; - int ret = 0; - - snprintf(buf, sizeof(buf), "/proc/%d/cmdline", upid); - ret = __read_proc(buf, buf, sizeof(buf)); - if (ret <= 0) { - _ERR("No proc directory (%d)\n", upid); - return NULL; - } - - _INFO("Caller=[%s]", buf); - - return strdup(buf); -} - -static char* -__get_request_type(const char *asm_req_json) -{ - if (asm_req_json == NULL) - return NULL; - - JsonParser *parser = json_parser_new(); - RET_IF_FAIL(parser != NULL, NULL); - - GError *parse_err = NULL; - json_parser_load_from_data(parser, asm_req_json, -1, &parse_err); - RET_IF_FAIL(parse_err == NULL, NULL); - - JsonNode *root = json_parser_get_root(parser); - RET_IF_FAIL(root != NULL, NULL); - - JsonObject *root_obj = json_node_get_object(root); - - const char *req_type = json_object_get_string_member(root_obj, "requestType"); - - return strdup(req_type); - -} - -gboolean -_dbus_on_asm_request(Dummyasm *object, GDBusMethodInvocation *invocation, const gchar *uaf_request_json) -{ - _INFO("_dbus_on_asm_request"); - - char *caller_path = __get_proc_path_of_dbus_caller(invocation); - if (caller_path == NULL) { - _ERR("Failed to get caller path"); - dummyasm_complete_asm_request(object, invocation, -1, NULL); - return true; - } - - if (strcmp(caller_path, _FIDO_SERVICE_PATH) != 0) { - _ERR("Only fido-service is allowed to call ASM"); - dummyasm_complete_asm_request(object, invocation, -1, NULL); - return true; - } - - char *req_type = __get_request_type(uaf_request_json); - if (req_type == NULL){ - dummyasm_complete_asm_request(object, invocation, -1, NULL); - return true; - } - - _INFO("request type=[%s]", req_type); - - if (strcmp(req_type, "GetInfo") == 0){ - dummyasm_complete_asm_request(object, invocation, 0, _GET_INFO_RESPONSE); - } - if (strcmp(req_type, "Register") == 0){ - dummyasm_complete_asm_request(object, invocation, 0, _REG_RESPONSE); - } - if (strcmp(req_type, "Authenticate") == 0){ - dummyasm_complete_asm_request(object, invocation, 0, _AUTH_RESPONSE); - } - if (strcmp(req_type, "Deregister") == 0){ - dummyasm_complete_asm_request(object, invocation, 0, _DEREG_RESPONSE); - } - if (strcmp(req_type, "GetRegistrations") == 0) { - dummyasm_complete_asm_request(object, invocation, 0, _GET_REGISTRATIONS_RESPONSE); - } - - return true; -} - -static void -on_bus_acquired (GDBusConnection *connection, const gchar *name, gpointer user_data) -{ - _INFO("on_bus_acquired"); - - GDBusInterfaceSkeleton* interface = NULL; - __dbus_obj = dummyasm_skeleton_new(); - if (__dbus_obj == NULL) { - return; - } - - interface = G_DBUS_INTERFACE_SKELETON(__dbus_obj); - if (!g_dbus_interface_skeleton_export(interface, connection, _DUMMY_ASM_SERVICE_DBUS_PATH, NULL)) { - return; - } - - _INFO("before g_signal_connect"); - g_signal_connect(__dbus_obj, "handle_asm_request", - G_CALLBACK(_dbus_on_asm_request), NULL); - -} - -static void -on_name_acquired (GDBusConnection *connection, - const gchar *name, - gpointer user_data) -{ - _INFO("on_name_acquired"); -} - -static void -on_name_lost (GDBusConnection *connection, - const gchar *name, - gpointer user_data) -{ - _INFO("on_name_lost"); - exit (1); -} - -static bool _initialize_dbus() -{ - _INFO("_initialize_dbus"); - owner_id = g_bus_own_name (G_BUS_TYPE_SYSTEM, - "org.tizen.dummyasm", - G_BUS_NAME_OWNER_FLAGS_NONE, - on_bus_acquired, - on_name_acquired, - on_name_lost, - NULL, - NULL); - - if(owner_id == 0) { - _INFO("owner_id is 0"); - return false; - } - - - return true; -} - -static void -_initialize(void) -{ -#if !GLIB_CHECK_VERSION(2,35,0) - g_type_init(); -#endif - - if (_initialize_dbus() == false) { - /* because dbus's initialize failed, we cannot continue any more. */ - exit(1); - } -} - -int -main(void) -{ - GMainLoop *mainloop = NULL; - - mainloop = g_main_loop_new(NULL, FALSE); - - _initialize(); - - g_main_loop_run(mainloop); - - - return 0; -} -- 2.7.4