From 68bb77e18766c49887eb0d35ccec202c20ef017c Mon Sep 17 00:00:00 2001
From: Aleksandr Lysikov <lysikov@inbox.ru>
Date: Sat, 18 May 2019 13:57:52 +0500
Subject: [PATCH] updated dap_chain_net_srv_client_auth() added module
 dap_server_http_db_auth

---
 CMakeLists.txt             |  2 +-
 dap_chain_net_srv_common.c | 34 ++++++++++++++--------------------
 dap_chain_net_srv_common.h |  3 +--
 3 files changed, 16 insertions(+), 23 deletions(-)

diff --git a/CMakeLists.txt b/CMakeLists.txt
index 5d3b84f..054d60b 100755
--- a/CMakeLists.txt
+++ b/CMakeLists.txt
@@ -14,7 +14,7 @@ set(DAP_CHAIN_NET_SRV_HEADERS
 add_library(${PROJECT_NAME} STATIC ${DAP_CHAIN_NET_SRV_SRCS} ${DAP_CHAIN_NET_SRV_HEADERS})
 
 
-target_link_libraries(dap_chain_net_srv dap_core dap_crypto dap_chain dap_chain_crypto dap_chain_net )
+target_link_libraries(dap_chain_net_srv dap_core dap_crypto dap_chain dap_chain_crypto dap_chain_net dap_server_http_db_auth)
 target_include_directories(dap_chain_net_srv INTERFACE .)
 
 set(${PROJECT_NAME}_DEFINITIONS CACHE INTERNAL "${PROJECT_NAME}: Definitions" FORCE)
diff --git a/dap_chain_net_srv_common.c b/dap_chain_net_srv_common.c
index e0b927f..c508ec2 100755
--- a/dap_chain_net_srv_common.c
+++ b/dap_chain_net_srv_common.c
@@ -30,6 +30,7 @@
 #include "dap_chain_datum_tx_items.h"
 #include "dap_chain_utxo.h"
 #include "dap_stream.h"
+#include "dap_server_http_db_auth.h"
 
 /**
  * copy a_value_dst to a_uid_src
@@ -72,14 +73,24 @@ void dap_chain_net_srv_abstract_set(dap_chain_net_srv_abstract_t *a_cond, uint8_
 /**
  *
  */
-uint64_t dap_chain_net_srv_client_auth(char *a_addr_base58, uint8_t *a_sign, size_t a_sign_size,
-        const dap_chain_net_srv_abstract_t **a_cond_out)
+uint64_t dap_chain_net_srv_client_auth(const char *a_service_key, const dap_chain_net_srv_abstract_t **a_cond_out)
 {
-    dap_chain_addr_t *l_addr = (a_addr_base58) ? dap_chain_str_to_addr(a_addr_base58) : NULL;
+    char *l_addr_base58;
+    char *l_sign_hash_str;
+    if(dap_server_http_db_auth_parse_service_key(a_service_key, &l_addr_base58, &l_sign_hash_str)) {
+        return 0;
+    }
+    if(!dap_server_http_db_auth_check_key(l_addr_base58, l_sign_hash_str)) {
+        // invalid signature
+        return 0;
+    }
+
+    dap_chain_addr_t *l_addr = (l_addr_base58) ? dap_chain_str_to_addr(l_addr_base58) : NULL;
     dap_chain_tx_out_cond_t *l_tx_out_cond = NULL;
     dap_chain_sign_type_t l_sig_type;
     if(l_addr)
         memcpy(&l_sig_type, &l_addr->sig_type, sizeof(dap_chain_sign_type_t));
+
     // Search all value in transactions with l_addr in 'out_cond' item
     uint64_t l_value = dap_chain_utxo_tx_cache_get_out_cond_value(l_addr, &l_tx_out_cond);
     DAP_DELETE(l_addr);
@@ -92,23 +103,6 @@ uint64_t dap_chain_net_srv_client_auth(char *a_addr_base58, uint8_t *a_sign, siz
     uint8_t *l_cond = dap_chain_datum_tx_out_cond_item_get_cond(l_tx_out_cond, &l_cond_size);
     uint8_t *l_pkey = dap_chain_datum_tx_out_cond_item_get_pkey(l_tx_out_cond, &l_pkey_size);
 
-    // create l_chain_sign for check a_sign
-    dap_chain_sign_t *l_chain_sign = DAP_NEW_Z_SIZE(dap_chain_sign_t,
-            sizeof(dap_chain_sign_t) + a_sign_size + l_pkey_size);
-    l_chain_sign->header.type = l_sig_type;
-    l_chain_sign->header.sign_size = l_pkey_size;
-    l_chain_sign->header.sign_pkey_size = l_pkey_size;
-    // write serialized public key to dap_chain_sign_t
-    memcpy(l_chain_sign->pkey_n_sign, l_pkey, l_pkey_size);
-    // write serialized signature to dap_chain_sign_t
-    memcpy(l_chain_sign->pkey_n_sign + l_pkey_size, a_sign, a_sign_size);
-
-    // check signature
-    if(dap_chain_sign_verify(l_chain_sign, a_sign, a_sign_size) != 1) {
-        // invalid signature
-        return 0;
-    }
-
     if(l_cond_size != sizeof(dap_chain_net_srv_abstract_t)) {
         return 0;
     }
diff --git a/dap_chain_net_srv_common.h b/dap_chain_net_srv_common.h
index 6d78a73..6fe166d 100755
--- a/dap_chain_net_srv_common.h
+++ b/dap_chain_net_srv_common.h
@@ -105,5 +105,4 @@ void dap_chain_net_srv_uid_set(dap_chain_net_srv_uid_t *a_uid_src, uint128_t a_v
 // generate new dap_chain_net_srv_uid_t
 bool dap_chain_net_srv_gen_uid(uint8_t *a_srv, size_t a_srv_size);
 
-uint64_t dap_chain_net_srv_client_auth(char *a_addr_base58, uint8_t *a_sign, size_t a_sign_size,
-        const dap_chain_net_srv_abstract_t **a_cond_out);
+uint64_t dap_chain_net_srv_client_auth(const char *a_service_key, const dap_chain_net_srv_abstract_t **a_cond_out);
-- 
GitLab