feat: Change ReconClient to fit new version Restful interface

This commit is contained in:
chenhuijun
2024-05-27 09:27:21 +08:00
parent f2562f5b40
commit 8bba77cd86
7 changed files with 22 additions and 66 deletions

View File

@@ -1149,8 +1149,11 @@ void DeviceManager::startCreateReconRecord()
QList<QVariant> record = variant.value<QList<QVariant>>();
QString scanID = record[0].toString();
QString referenceID = record[1].toString();
QString patientID = record[2].toString();;
emit createScanToRecon(scanID, patientID, referenceID, RECON_TRANSFER_PATH + "/" + scanID);
// QString patientID = record[2].toString();;
//TODO:need StudyUID & MPPS Uid
QString studyUID;
QString mppsUID;
emit createScanToRecon(scanID, studyUID,mppsUID, referenceID, RECON_TRANSFER_PATH + "/" + scanID);
}
startTransfer();
}

View File

@@ -166,7 +166,7 @@ signals:
void responseCheckDataQuality(const QString& aResponse);
//Recon
void createEmptyScanToRecon(const QString& aScanID, const QString& aPath);
void createScanToRecon(const QString& aScanID, const QString& aPatientID, const QString& aReferenceID, const QString& aPath);
void createScanToRecon(const QString& aScanID, const QString& aStudyUID,const QString& aMPPSUID, const QString& aReferenceID, const QString& aPath);
void queryScanStatusToRecon(const QStringList& aScanIDs);
void updateReconStateFinished();
//GUI

View File

@@ -3,7 +3,8 @@
#include <string>
struct Scan{
std::string ScanID;
std::string PatientID;
std::string StudyUID;
std::string MPPSUID;
std::string ReferenceID;
std::string ReferencePath;
int Type;
@@ -22,7 +23,7 @@ struct PACSSetting
std::string AETitle;
std::string ServerAETitle;
std::string ServerIP;
int Port = 0;;
int Port = 0;
};
#endif // __SCAN_H__

View File

@@ -7,7 +7,7 @@
namespace
{
const char *CREATE_URL = "/Scan/Create/";
const char *CHECK_URL = "/v/";
const char *STATE_URL = "/State/";
const char *QUERY_SCAN_URL = "/Scan/Query/";
const char *QUERY_VERSION_URL = "/Version/";
const char *QUERY_RECON_URL = "/Task/Query/";
@@ -36,7 +36,7 @@ RequestResult ReconClient::CheckActive()
{
std::string content;
content.append("1");
auto resp = mRequest.post(mHost + CHECK_URL, content, mHeaders);
auto resp = mRequest.post(mHost + STATE_URL, content, mHeaders);
if (resp.httpCode() == 200)
{
return RequestResult::Success();
@@ -52,7 +52,14 @@ RequestResult ReconClient::Create(const Scan &aScan)
{
cJSON *obj = cJSON_CreateObject();
cJSON_AddStringToObject(obj, "ScanID", aScan.ScanID.c_str());
cJSON_AddStringToObject(obj, "PatientID", aScan.PatientID.c_str());
if (aScan.StudyUID.length()>0)
{
cJSON_AddStringToObject(obj, "StudyUID", aScan.StudyUID.c_str());
}
if (aScan.MPPSUID.length()>0)
{
cJSON_AddStringToObject(obj, "MPPSUID", aScan.MPPSUID.c_str());
}
cJSON_AddStringToObject(obj, "ReferencePath", aScan.ReferencePath.c_str());
if (!aScan.ReferencePath.empty())
{
@@ -111,59 +118,6 @@ RequestResult ReconClient::QueryScan(const std::string &aScanID, int &state)
}
}
RequestResult ReconClient::QueryReconID(const std::string &aScanID, std::string &aReconID)
{
cJSON *obj = cJSON_CreateObject();
cJSON_AddStringToObject(obj, "ScanID", aScanID.data());
char *str = cJSON_Print(obj);
cJSON_Delete(obj);
std::string content;
content.append(str);
free(str);
auto resp = mRequest.post(mHost + QUERY_RECON_URL, content, mHeaders);
if (resp.httpCode() == 204)
{
return RequestResult::Success();
}
else if (resp.httpCode() == 200)
{
aReconID = resp.getContent();
return RequestResult::Success(aReconID);
}
else
{
mErrorMessage = resp.getContent();
return RequestResult::Fail(mErrorMessage);
}
}
RequestResult ReconClient::QueryReconTask(const std::string &aReconID, TaskQueryResult &aTask)
{
cJSON *obj = cJSON_CreateObject();
cJSON_AddStringToObject(obj, "ReconID", aReconID.data());
char *str = cJSON_Print(obj);
cJSON_Delete(obj);
std::string content;
content.append(str);
free(str);
auto resp = mRequest.post(mHost + QUERY_RECON_URL, content, mHeaders);
if (resp.httpCode() == 200)
{
cJSON *task = cJSON_Parse(resp.getContent().data());
aTask.ReconID = cJSON_GetObjectItem(task, "ReconID")->valuestring;
aTask.ScanID = cJSON_GetObjectItem(task, "ScanID")->valuestring;
aTask.Start = cJSON_GetObjectItem(task, "Start")->valueint != 0;
aTask.SeqID = cJSON_GetObjectItem(task, "SeqID")->valueint;
cJSON_Delete(task);
return RequestResult::Success();
}
else
{
mErrorMessage = resp.getContent();
return RequestResult::Fail(mErrorMessage);
}
}
RequestResult ReconClient::QueryVersion()
{
std::string content;

View File

@@ -13,8 +13,6 @@ public:
RequestResult CheckActive();
RequestResult Create(const Scan &aScan);
RequestResult QueryScan(const std::string &aScanID, int &state);
RequestResult QueryReconID(const std::string &aScanID, std::string &aReconID);
RequestResult QueryReconTask(const std::string &aReconID, TaskQueryResult &aTask);
RequestResult QueryVersion();
RequestResult SetPACSSetting(const PACSSetting &aSetting);

View File

@@ -62,9 +62,9 @@ void ReconManager::createEmptyScan(const QString& aScanID, const QString& aPath)
}
}
void ReconManager::createScan(const QString& aScanID, const QString& aPatientID, const QString& aReferenceID, const QString& aPath)
void ReconManager::createScan(const QString& aScanID, const QString& aStudyUID,const QString& aMPPSUID, const QString& aReferenceID, const QString& aPath)
{
Scan scan{aScanID.toStdString(), aPatientID.toStdString(), aReferenceID.toStdString(), aPath.toStdString(), 1};
Scan scan{aScanID.toStdString(), aStudyUID.toStdString(), aMPPSUID.toStdString(), aReferenceID.toStdString(), aPath.toStdString(),1};
auto response = mReconClient->Create(scan);
if(response.good())
{

View File

@@ -20,7 +20,7 @@ public:
public slots:
void createEmptyScan(const QString& aScanID, const QString& aPath);
void createScan(const QString& aScanID, const QString& aPatientID, const QString& aReferenceID, const QString& aPath);
void createScan(const QString& aScanID, const QString& aStudyUID,const QString& aMPPSUID, const QString& aReferenceID, const QString& aPath);
void queryReconStatus(const QStringList& aScanIDs);
void setPacsSettings(const QString& aClientAETitle, const QString& aServerAETitle, const QString& aServerIP, int aServerPort);
void checkReconConnection();