Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
S
sgxwallet
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
董子豪
sgxwallet
Commits
784064c3
Unverified
Commit
784064c3
authored
Jun 07, 2021
by
Oleh Nikolaiev
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
SKALE-3951 add rsp methods
parent
d9b3ba36
Changes
5
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
321 additions
and
24 deletions
+321
-24
Makefile.am
Makefile.am
+3
-4
RspMessage.cpp
zmq_src/RspMessage.cpp
+112
-0
RspMessage.h
zmq_src/RspMessage.h
+187
-0
ZMQClient.h
zmq_src/ZMQClient.h
+1
-1
ZMQMessage.cpp
zmq_src/ZMQMessage.cpp
+18
-19
No files found.
Makefile.am
View file @
784064c3
...
...
@@ -70,14 +70,13 @@ bin_PROGRAMS = sgxwallet testw sgx_util
## have to be explicitly listed
COMMON_SRC
=
SGXException.cpp ExitHandler.cpp zmq_src/ZMQClient.cpp zmq_src/BLSSignRspMessage.cpp
\
zmq_src/ECDSASignRspMessage.cpp zmq_src/ReqMessage.cpp
\
COMMON_SRC
=
SGXException.cpp ExitHandler.cpp zmq_src/ZMQClient.cpp zmq_src/RspMessage.cpp zmq_src/ReqMessage.cpp
\
zmq_src/ZMQMessage.cpp zmq_src/ZMQServer.cpp zmq_src/ServerWorker.cpp
\
InvalidStateException.cpp Exception.cpp InvalidArgumentException.cpp Log.cpp
\
SGXWalletServer.cpp SGXRegistrationServer.cpp CSRManagerServer.cpp BLSCrypto.cpp
\
DKGCrypto.cpp ServerInit.cpp BLSPrivateKeyShareSGX.cpp LevelDB.cpp ServerDataChecker.cpp SEKManager.cpp
\
third_party/intel/sgx_stub.c third_party/intel/sgx_detect_linux.c third_party/intel/create_enclave.c
third_party/intel/oc_alloc.c
\
ECDSAImpl.c TestUtils.cpp sgxwallet.c SGXInfoServer.cpp ECDSACrypto.cpp
third_party/intel/sgx_stub.c third_party/intel/sgx_detect_linux.c third_party/intel/create_enclave.c
\
third_party/intel/oc_alloc.c
ECDSAImpl.c TestUtils.cpp sgxwallet.c SGXInfoServer.cpp ECDSACrypto.cpp
COMMON_ENCLAVE_SRC
=
secure_enclave_u.c secure_enclave_u.h
sgxwallet_SOURCES
=
sgxwall.cpp
$(COMMON_SRC)
...
...
zmq_src/RspMessage.cpp
0 → 100644
View file @
784064c3
/*
Copyright (C) 2018- SKALE Labs
This file is part of sgxwallet.
sgxwallet is free software: you can redistribute it and/or modify
it under the terms of the GNU Affero General Public License as published
by the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
sgxwallet is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU Affero General Public License for more details.
You should have received a copy of the GNU Affero General Public License
along with sgxwallet. If not, see <https://www.gnu.org/licenses/>.
@file RspMessage.cpp
@author Oleh Nikolaiev
@date 2021
*/
#include "SGXWalletServer.hpp"
#include "RspMessage.h"
Json
::
Value
ECDSASignRspMessage
::
process
()
{
assert
(
false
);
}
string
ECDSASignRspMessage
::
getSignature
()
{
string
r
=
getStringRapid
(
"signature_r"
);
string
v
=
getStringRapid
(
"signature_v"
);
string
s
=
getStringRapid
(
"signature_s"
);
auto
ret
=
v
+
":"
+
r
.
substr
(
2
)
+
":"
+
s
.
substr
(
2
);
return
ret
;
}
Json
::
Value
BLSSignRspMessage
::
process
()
{
assert
(
false
);
}
Json
::
Value
importBLSRspMessage
::
process
()
{
assert
(
false
);
}
Json
::
Value
importECDSARspMessage
::
process
()
{
assert
(
false
);
}
Json
::
Value
generateECDSARspMessage
::
process
()
{
assert
(
false
);
}
Json
::
Value
getPublicECDSARspMessage
::
process
()
{
assert
(
false
);
}
Json
::
Value
generateDKGPolyRspMessage
::
process
()
{
assert
(
false
);
}
Json
::
Value
getVerificationVectorRspMessage
::
process
()
{
assert
(
false
);
}
Json
::
Value
getSecretShareRspMessage
::
process
()
{
assert
(
false
);
}
Json
::
Value
dkgVerificationRspMessage
::
process
()
{
assert
(
false
);
}
Json
::
Value
createBLSPrivateKeyRspMessage
::
process
()
{
assert
(
false
);
}
Json
::
Value
getBLSPublicRspMessage
::
process
()
{
assert
(
false
);
}
Json
::
Value
getAllBLSPublicKeysRspMessage
::
process
()
{
assert
(
false
);
}
Json
::
Value
complaintResponseRspMessage
::
process
()
{
assert
(
false
);
}
Json
::
Value
multG2RspMessage
::
process
()
{
assert
(
false
);
}
Json
::
Value
isPolyExistsRspMessage
::
process
()
{
assert
(
false
);
}
Json
::
Value
getServerStatusRspMessage
::
process
()
{
assert
(
false
);
}
Json
::
Value
getServerVersionRspMessage
::
process
()
{
assert
(
false
);
}
Json
::
Value
deleteBLSKeyRspMessage
::
process
()
{
assert
(
false
);
}
zmq_src/RspMessage.h
0 → 100644
View file @
784064c3
/*
Copyright (C) 2018- SKALE Labs
This file is part of sgxwallet.
sgxwallet is free software: you can redistribute it and/or modify
it under the terms of the GNU Affero General Public License as published
by the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
sgxwallet is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU Affero General Public License for more details.
You should have received a copy of the GNU Affero General Public License
along with sgxwallet. If not, see <https://www.gnu.org/licenses/>.
@file RspMessage.h
@author Oleh Nikolaiev
@date 2021
*/
#ifndef SGXWALLET_RSPMESSAGE_H
#define SGXWALLET_RSPMESSAGE_H
#include "ZMQMessage.h"
class
ECDSASignRspMessage
:
public
ZMQMessage
{
public
:
ECDSASignRspMessage
(
shared_ptr
<
rapidjson
::
Document
>
&
_d
)
:
ZMQMessage
(
_d
)
{};
virtual
Json
::
Value
process
();
string
getSignature
();
};
class
BLSSignRspMessage
:
public
ZMQMessage
{
public
:
BLSSignRspMessage
(
shared_ptr
<
rapidjson
::
Document
>&
_d
)
:
ZMQMessage
(
_d
)
{};
virtual
Json
::
Value
process
();
string
getSigShare
()
{
return
getStringRapid
(
"signatureShare"
);
}
};
class
importBLSRspMessage
:
public
ZMQMessage
{
public
:
importBLSRspMessage
(
shared_ptr
<
rapidjson
::
Document
>&
_d
)
:
ZMQMessage
(
_d
)
{};
virtual
Json
::
Value
process
();
};
class
importECDSARspMessage
:
public
ZMQMessage
{
public
:
importECDSARspMessage
(
shared_ptr
<
rapidjson
::
Document
>&
_d
)
:
ZMQMessage
(
_d
)
{};
virtual
Json
::
Value
process
();
};
class
generateECDSARspMessage
:
public
ZMQMessage
{
public
:
generateECDSARspMessage
(
shared_ptr
<
rapidjson
::
Document
>&
_d
)
:
ZMQMessage
(
_d
)
{};
virtual
Json
::
Value
process
();
};
class
getPublicECDSARspMessage
:
public
ZMQMessage
{
public
:
getPublicECDSARspMessage
(
shared_ptr
<
rapidjson
::
Document
>&
_d
)
:
ZMQMessage
(
_d
)
{};
virtual
Json
::
Value
process
();
};
class
generateDKGPolyRspMessage
:
public
ZMQMessage
{
public
:
generateDKGPolyRspMessage
(
shared_ptr
<
rapidjson
::
Document
>&
_d
)
:
ZMQMessage
(
_d
)
{};
virtual
Json
::
Value
process
();
};
class
getVerificationVectorRspMessage
:
public
ZMQMessage
{
public
:
getVerificationVectorRspMessage
(
shared_ptr
<
rapidjson
::
Document
>&
_d
)
:
ZMQMessage
(
_d
)
{};
virtual
Json
::
Value
process
();
};
class
getSecretShareRspMessage
:
public
ZMQMessage
{
public
:
getSecretShareRspMessage
(
shared_ptr
<
rapidjson
::
Document
>&
_d
)
:
ZMQMessage
(
_d
)
{};
virtual
Json
::
Value
process
();
};
class
dkgVerificationRspMessage
:
public
ZMQMessage
{
public
:
dkgVerificationRspMessage
(
shared_ptr
<
rapidjson
::
Document
>&
_d
)
:
ZMQMessage
(
_d
)
{};
virtual
Json
::
Value
process
();
};
class
createBLSPrivateKeyRspMessage
:
public
ZMQMessage
{
public
:
createBLSPrivateKeyRspMessage
(
shared_ptr
<
rapidjson
::
Document
>&
_d
)
:
ZMQMessage
(
_d
)
{};
virtual
Json
::
Value
process
();
};
class
getBLSPublicRspMessage
:
public
ZMQMessage
{
public
:
getBLSPublicRspMessage
(
shared_ptr
<
rapidjson
::
Document
>&
_d
)
:
ZMQMessage
(
_d
)
{};
virtual
Json
::
Value
process
();
};
class
getAllBLSPublicKeysRspMessage
:
public
ZMQMessage
{
public
:
getAllBLSPublicKeysRspMessage
(
shared_ptr
<
rapidjson
::
Document
>&
_d
)
:
ZMQMessage
(
_d
)
{};
virtual
Json
::
Value
process
();
};
class
complaintResponseRspMessage
:
public
ZMQMessage
{
public
:
complaintResponseRspMessage
(
shared_ptr
<
rapidjson
::
Document
>&
_d
)
:
ZMQMessage
(
_d
)
{};
virtual
Json
::
Value
process
();
};
class
multG2RspMessage
:
public
ZMQMessage
{
public
:
multG2RspMessage
(
shared_ptr
<
rapidjson
::
Document
>&
_d
)
:
ZMQMessage
(
_d
)
{};
virtual
Json
::
Value
process
();
};
class
isPolyExistsRspMessage
:
public
ZMQMessage
{
public
:
isPolyExistsRspMessage
(
shared_ptr
<
rapidjson
::
Document
>&
_d
)
:
ZMQMessage
(
_d
)
{};
virtual
Json
::
Value
process
();
};
class
getServerStatusRspMessage
:
public
ZMQMessage
{
public
:
getServerStatusRspMessage
(
shared_ptr
<
rapidjson
::
Document
>&
_d
)
:
ZMQMessage
(
_d
)
{};
virtual
Json
::
Value
process
();
};
class
getServerVersionRspMessage
:
public
ZMQMessage
{
public
:
getServerVersionRspMessage
(
shared_ptr
<
rapidjson
::
Document
>&
_d
)
:
ZMQMessage
(
_d
)
{};
virtual
Json
::
Value
process
();
};
class
deleteBLSKeyRspMessage
:
public
ZMQMessage
{
public
:
deleteBLSKeyRspMessage
(
shared_ptr
<
rapidjson
::
Document
>&
_d
)
:
ZMQMessage
(
_d
)
{};
virtual
Json
::
Value
process
();
};
#endif //SGXWALLET_RSPMESSAGE_H
zmq_src/ZMQClient.h
View file @
784064c3
...
...
@@ -75,7 +75,7 @@ public:
ZMQClient
(
const
string
&
ip
,
uint16_t
port
,
bool
_sign
,
const
string
&
_certPathName
,
const
string
&
_certKeyName
);
void
reconnect
()
;
void
reconnect
();
static
pair
<
EVP_PKEY
*
,
X509
*>
readPublicKeyFromCertStr
(
const
string
&
_cert
);
...
...
zmq_src/ZMQMessage.cpp
View file @
784064c3
...
...
@@ -30,8 +30,7 @@
#include "ZMQClient.h"
#include "SGXWalletServer.hpp"
#include "ReqMessage.h"
#include "BLSSignRspMessage.h"
#include "ECDSASignRspMessage.h"
#include "RspMessage.h"
#include "ZMQMessage.h"
...
...
@@ -250,55 +249,55 @@ shared_ptr <ZMQMessage> ZMQMessage::buildResponse(string &_type, shared_ptr <rap
ret
=
make_shared
<
ECDSASignRspMessage
>
(
_d
);
break
;
case
ENUM_IMPORT_BLS_RSP
:
ret
=
make_shared
<
ECDSASign
RspMessage
>
(
_d
);
ret
=
make_shared
<
importBLS
RspMessage
>
(
_d
);
break
;
case
ENUM_IMPORT_ECDSA_RSP
:
ret
=
make_shared
<
ECDSASign
RspMessage
>
(
_d
);
ret
=
make_shared
<
importECDSA
RspMessage
>
(
_d
);
break
;
case
ENUM_GENERATE_ECDSA_RSP
:
ret
=
make_shared
<
ECDSASign
RspMessage
>
(
_d
);
ret
=
make_shared
<
generateECDSA
RspMessage
>
(
_d
);
break
;
case
ENUM_GET_PUBLIC_ECDSA_RSP
:
ret
=
make_shared
<
ECDSASign
RspMessage
>
(
_d
);
ret
=
make_shared
<
getPublicECDSA
RspMessage
>
(
_d
);
break
;
case
ENUM_GENERATE_DKG_POLY_RSP
:
ret
=
make_shared
<
ECDSASign
RspMessage
>
(
_d
);
ret
=
make_shared
<
generateDKGPoly
RspMessage
>
(
_d
);
break
;
case
ENUM_GET_VV_RSP
:
ret
=
make_shared
<
ECDSASign
RspMessage
>
(
_d
);
ret
=
make_shared
<
getVerificationVector
RspMessage
>
(
_d
);
break
;
case
ENUM_GET_SECRET_SHARE_RSP
:
ret
=
make_shared
<
ECDSASign
RspMessage
>
(
_d
);
ret
=
make_shared
<
getSecretShare
RspMessage
>
(
_d
);
break
;
case
ENUM_DKG_VERIFY_RSP
:
ret
=
make_shared
<
ECDSASig
nRspMessage
>
(
_d
);
ret
=
make_shared
<
dkgVerificatio
nRspMessage
>
(
_d
);
break
;
case
ENUM_CREATE_BLS_PRIVATE_RSP
:
ret
=
make_shared
<
ECDSASign
RspMessage
>
(
_d
);
ret
=
make_shared
<
createBLSPrivateKey
RspMessage
>
(
_d
);
break
;
case
ENUM_GET_BLS_PUBLIC_RSP
:
ret
=
make_shared
<
ECDSASign
RspMessage
>
(
_d
);
ret
=
make_shared
<
getBLSPublic
RspMessage
>
(
_d
);
break
;
case
ENUM_GET_ALL_BLS_PUBLIC_RSP
:
ret
=
make_shared
<
ECDSASign
RspMessage
>
(
_d
);
ret
=
make_shared
<
getAllBLSPublicKeys
RspMessage
>
(
_d
);
break
;
case
ENUM_COMPLAINT_RESPONSE_RSP
:
ret
=
make_shared
<
ECDSASign
RspMessage
>
(
_d
);
ret
=
make_shared
<
complaintResponse
RspMessage
>
(
_d
);
break
;
case
ENUM_MULT_G2_RSP
:
ret
=
make_shared
<
ECDSASign
RspMessage
>
(
_d
);
ret
=
make_shared
<
multG2
RspMessage
>
(
_d
);
break
;
case
ENUM_IS_POLY_EXISTS_RSP
:
ret
=
make_shared
<
ECDSASign
RspMessage
>
(
_d
);
ret
=
make_shared
<
isPolyExists
RspMessage
>
(
_d
);
break
;
case
ENUM_GET_SERVER_STATUS_RSP
:
ret
=
make_shared
<
ECDSASign
RspMessage
>
(
_d
);
ret
=
make_shared
<
getServerStatus
RspMessage
>
(
_d
);
break
;
case
ENUM_GET_SERVER_VERSION_RSP
:
ret
=
make_shared
<
ECDSASig
nRspMessage
>
(
_d
);
ret
=
make_shared
<
getServerVersio
nRspMessage
>
(
_d
);
break
;
case
ENUM_DELETE_BLS_KEY_RSP
:
ret
=
make_shared
<
ECDSASign
RspMessage
>
(
_d
);
ret
=
make_shared
<
deleteBLSKey
RspMessage
>
(
_d
);
break
;
default
:
break
;
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment