加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
克隆/下载
formatter.cpp 7.98 KB
一键复制 编辑 原始数据 按行查看 历史
Askaley 提交于 2024-09-25 13:52 . fix cros.
#include "formatter.h"
#include <QDebug>
#include <QDir>
#include <QFile>
#include <QJsonDocument>
#include <QJsonObject>
#include <QtHttpServer/QHttpServerResponse>
#include "dcmtk/dcmdata/dcdict.h"
#include "dcmtk/dcmdata/dcfilefo.h"
#include "dcmtk/ofstd/offile.h"
#include "dcmtk/dcmdata/dcdeftag.h"
#include "dcmtk/dcmdata/dcuid.h"
Formatter::Formatter(const QString &dbPath):m_dbPath(dbPath)
{
DcmDataDictionary &dict = dcmDataDict.wrlock();
QString dictPath = QDir::currentPath() + "/etc/dicom.dic";
bool loaded = dict.loadDictionary(dictPath.toLocal8Bit());
if (!loaded) {
qFatal() << "Load dicom dict failed: " << dictPath;
}
dcmDataDict.rdunlock();
QDir dir(m_dbPath);
if (!dir.exists()) {
dir.mkpath(m_dbPath);
}
if (!dir.exists("lockfile")) {
QFile lf(m_dbPath + "/" + "lockfile");
if (!lf.open(QIODevice::WriteOnly)) {
qFatal() << "Create lockfile failed: " << lf.fileName();
}
lf.close();
}
}
QHttpServerResponse Formatter::process(const QByteArray &data) {
QJsonObject resp;
QJsonParseError err;
QJsonDocument doc = QJsonDocument::fromJson(data, &err);
if (err.error != QJsonParseError::ParseError::NoError) {
resp.insert("success", false);
resp.insert("message", "Json parse failed: " + err.errorString());
return QHttpServerResponse(resp, QHttpServerResponse::StatusCode::BadRequest);
}
QJsonObject json = doc.object();
if (json.empty()) {
resp.insert("success", false);
resp.insert("message", "Empty request data.");
return QHttpServerResponse(resp, QHttpServerResponse::StatusCode::BadRequest);
}
DcmFileFormat ff;
DcmDataset *dset = ff.getDataset();
QString uid;
QString val = json.value("SpecificCharacterSet").toString();
if (val.isEmpty()) {
val = "GB18030";
}
dset->putAndInsertString(DCM_SpecificCharacterSet, val.toLocal8Bit());
uid = json.value("StudyInstanceUID").toString();
if (uid.isEmpty()) {
char uidBuf[100];
dcmGenerateUniqueIdentifier(uidBuf, SITE_STUDY_UID_ROOT);
uid = uidBuf;
}
dset->putAndInsertString(DCM_StudyInstanceUID, uid.toLocal8Bit());
val = json.value("AccessionNumber").toString();
if (!val.isEmpty()) {
dset->putAndInsertString(DCM_AccessionNumber, val.toLocal8Bit());
}
val = json.value("PatientName").toString();
if (!val.isEmpty()) {
dset->putAndInsertString(DCM_PatientName, val.toLocal8Bit());
}
val = json.value("PatientID").toString();
if (!val.isEmpty()) {
dset->putAndInsertString(DCM_PatientID, val.toLocal8Bit());
}
val = json.value("PatientBirthDate").toString();
if (!val.isEmpty()) {
dset->putAndInsertString(DCM_PatientBirthDate, val.toLocal8Bit());
}
val = json.value("PatientSex").toString();
if (!val.isEmpty()) {
dset->putAndInsertString(DCM_PatientSex, val.toLocal8Bit());
}
val = json.value("MedicalAlerts").toString();
if (!val.isEmpty()) {
dset->putAndInsertString(DCM_MedicalAlerts, val.toLocal8Bit());
}
val = json.value("Allergies").toString();
if (!val.isEmpty()) {
dset->putAndInsertString(DCM_Allergies, val.toLocal8Bit());
}
val = json.value("RequestingPhysician").toString();
if (!val.isEmpty()) {
dset->putAndInsertString(DCM_RequestingPhysician, val.toLocal8Bit());
}
val = json.value("RequestedProcedureDescription").toString();
if (!val.isEmpty()) {
dset->putAndInsertString(DCM_RequestedProcedureDescription, val.toLocal8Bit());
}
val = json.value("RequestedProcedureID").toString();
if (!val.isEmpty()) {
dset->putAndInsertString(DCM_RequestedProcedureID, val.toLocal8Bit());
}
val = json.value("RequestedProcedurePriority").toString();
if (!val.isEmpty()) {
dset->putAndInsertString(DCM_RequestedProcedurePriority, val.toLocal8Bit());
}
QJsonObject seq = json.value("ScheduledProcedureStepSequence").toObject();
if (!seq.isEmpty()) {
DcmItem *item = NULL;
OFCondition cond = dset->findOrCreateSequenceItem(DCM_ScheduledProcedureStepSequence, item);
if (cond.good() || item) {
val = seq.value("Modality").toString();
if (!val.isEmpty()) {
item->putAndInsertString(DCM_Modality, val.toLocal8Bit());
}
val = seq.value("RequestedContrastAgent").toString();
if (!val.isEmpty()) {
item->putAndInsertString(DCM_RequestedContrastAgent, val.toLocal8Bit());
}
val = seq.value("ScheduledStationAETitle").toString();
if (!val.isEmpty()) {
item->putAndInsertString(DCM_ScheduledStationAETitle, val.toLocal8Bit());
}
val = seq.value("ScheduledProcedureStepStartDate").toString();
if (!val.isEmpty()) {
item->putAndInsertString(DCM_ScheduledProcedureStepStartDate, val.toLocal8Bit());
}
val = seq.value("ScheduledProcedureStepStartTime").toString();
if (!val.isEmpty()) {
item->putAndInsertString(DCM_ScheduledProcedureStepStartTime, val.toLocal8Bit());
}
val = seq.value("ScheduledProcedureStepEndDate").toString();
if (!val.isEmpty()) {
item->putAndInsertString(DCM_ScheduledProcedureStepEndDate, val.toLocal8Bit());
}
val = seq.value("ScheduledProcedureStepEndTime").toString();
if (!val.isEmpty()) {
item->putAndInsertString(DCM_ScheduledProcedureStepEndTime, val.toLocal8Bit());
}
val = seq.value("ScheduledPerformingPhysicianName").toString();
if (!val.isEmpty()) {
item->putAndInsertString(DCM_ScheduledPerformingPhysicianName, val.toLocal8Bit());
}
val = seq.value("ScheduledProcedureStepDescription").toString();
if (!val.isEmpty()) {
item->putAndInsertString(DCM_ScheduledProcedureStepDescription, val.toLocal8Bit());
}
val = seq.value("ScheduledProcedureStepID").toString();
if (!val.isEmpty()) {
item->putAndInsertString(DCM_ScheduledProcedureStepID, val.toLocal8Bit());
}
val = seq.value("ScheduledStationName").toString();
if (!val.isEmpty()) {
item->putAndInsertString(DCM_ScheduledStationName, val.toLocal8Bit());
}
val = seq.value("ScheduledProcedureStepLocation").toString();
if (!val.isEmpty()) {
item->putAndInsertString(DCM_ScheduledProcedureStepLocation, val.toLocal8Bit());
}
val = seq.value("PreMedication").toString();
if (!val.isEmpty()) {
item->putAndInsertString(DCM_PreMedication, val.toLocal8Bit());
}
val = seq.value("CommentsOnTheScheduledProcedureStep").toString();
if (!val.isEmpty()) {
item->putAndInsertString(DCM_CommentsOnTheScheduledProcedureStep, val.toLocal8Bit());
}
} else {
qFatal() << "Insert sequence item failed: " << cond.text();
}
}
QString filename = m_dbPath + "/" + uid + ".wl";
OFFilename fn(filename.toLocal8Bit());
OFCondition cond = ff.saveFile(fn, EXS_LittleEndianImplicit);
if (cond.bad()) {
qFatal() << "Save worklist file failed: " << cond.text() << "File name: " << filename;
resp.insert("success", false);
resp.insert("message", cond.text());
return QHttpServerResponse(resp, QHttpServerResponse::StatusCode::InternalServerError);
}
resp.insert("success", true);
resp.insert("message", "ok");
QHttpServerResponse rs = QHttpServerResponse(resp, QHttpServerResponse::StatusCode::Ok);
rs.setHeader("Access-Control-Allow-Origin","*");
rs.setHeader("Access-Control-Allow-Methods","*");
rs.setHeader("Access-Control-Allow-Headers","*");
return rs;
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化