Update parameter list API
[platform/core/security/key-manager.git] / src / manager / common / protocols.cpp
index 6e80011..91a3497 100644 (file)
@@ -25,6 +25,7 @@
 #include <protocols.h>
 
 #include <dpl/serialization.h>
+#include <ckm/ckm-type.h>
 
 namespace CKM {
 
@@ -32,31 +33,9 @@ char const * const SERVICE_SOCKET_ECHO = "/tmp/.central-key-manager-echo.sock";
 char const * const SERVICE_SOCKET_CKM_CONTROL = "/tmp/.central-key-manager-api-control.sock";
 char const * const SERVICE_SOCKET_CKM_STORAGE = "/tmp/.central-key-manager-api-storage.sock";
 char const * const SERVICE_SOCKET_OCSP = "/tmp/.central-key-manager-api-ocsp.sock";
+char const * const SERVICE_SOCKET_ENCRYPTION = "/tmp/.central-key-manager-api-encryption.sock";
 char const * const LABEL_NAME_SEPARATOR = " ";
-
-namespace {
-const char* const DB_PERM_READ        = "R";
-const char* const DB_PERM_READ_REMOVE = "RD";
-}
-
-const char* toDBPermission(Permission access_right_type) {
-    switch(access_right_type) {
-    case Permission::READ:          return DB_PERM_READ;
-    case Permission::READ_REMOVE:   return DB_PERM_READ_REMOVE;
-    default:
-        // TODO
-        throw 1;
-    }
-}
-
-Permission toPermission(const std::string &input_DB_data) {
-    if(input_DB_data == DB_PERM_READ_REMOVE)
-        return Permission::READ_REMOVE;
-    else if(input_DB_data == DB_PERM_READ)
-        return Permission::READ;
-    else
-        return Permission::NONE;
-}
+char const * const LABEL_SYSTEM_DB = "/";
 
 
 PKCS12Serializable::PKCS12Serializable() {}
@@ -115,7 +94,7 @@ void PKCS12Serializable::Serialize(IStream &stream) const
     // throw an error and close the connection).
     Serialization::Serialize(stream, static_cast<size_t>(isAnyKeyPresent?1:0));
     if(keyPtr) {
-        Serialization::Serialize(stream, DBDataType(keyPtr->getType()));
+        Serialization::Serialize(stream, DataType(keyPtr->getType()));
         Serialization::Serialize(stream, keyPtr->getDER());
     }
 
@@ -131,5 +110,66 @@ void PKCS12Serializable::Serialize(IStream &stream) const
         Serialization::Serialize(stream, it->getDER());
 };
 
+
+CryptoAlgorithmSerializable::CryptoAlgorithmSerializable() {}
+CryptoAlgorithmSerializable::CryptoAlgorithmSerializable(const CryptoAlgorithm &algo) :
+        CryptoAlgorithm(algo)
+{
+}
+
+CryptoAlgorithmSerializable::CryptoAlgorithmSerializable(IStream &stream)
+{
+    size_t plen = 0;
+    Deserializer<size_t>::Deserialize(stream, plen);
+    while(plen) {
+        ParamName name;
+        uint64_t integer;
+        RawBuffer buffer;
+        int tmpName;
+        Deserializer<int>::Deserialize(stream, tmpName);
+        name = static_cast<ParamName>(tmpName);
+        switch (name) {
+        case ParamName::ED_IV:
+        case ParamName::ED_AAD:
+        case ParamName::ED_LABEL:
+            Deserializer<RawBuffer>::Deserialize(stream, buffer);
+            setParam(name, buffer);
+            break;
+
+        case ParamName::ALGO_TYPE:
+        case ParamName::ED_CTR_LEN:
+        case ParamName::ED_TAG_LEN:
+        case ParamName::GEN_KEY_LEN:
+        case ParamName::GEN_EC:
+        case ParamName::SV_HASH_ALGO:
+        case ParamName::SV_RSA_PADDING:
+            Deserializer<uint64_t>::Deserialize(stream, integer);
+            setParam(name, integer);
+            break;
+
+        default:
+            ThrowMsg(UnsupportedParam, "Unsupported param name");
+        }
+        plen--;
+    }
+}
+
+void CryptoAlgorithmSerializable::Serialize(IStream &stream) const
+{
+    Serializer<size_t>::Serialize(stream, m_params.size());
+    for(const auto& it : m_params) {
+        Serializer<int>::Serialize(stream, static_cast<int>(it.first));
+        uint64_t integer;
+        RawBuffer buffer;
+        if (it.second->getInt(integer))
+            Serializer<uint64_t>::Serialize(stream, integer);
+        else if (it.second->getBuffer(buffer))
+            Serializer<RawBuffer>::Serialize(stream, buffer);
+        else
+            ThrowMsg(UnsupportedParam, "Unsupported param type");
+    }
+
+}
+
 } // namespace CKM