From 07c5f6ec23fcf9237a24e71adcfacabce677f818 Mon Sep 17 00:00:00 2001 From: Renaud G Date: Fri, 29 Apr 2022 10:48:09 +0200 Subject: Change file organization. --- src/bin/webserver/diceserver.cpp | 237 +++++++++++++++++++++++++++++++++++++++ 1 file changed, 237 insertions(+) create mode 100644 src/bin/webserver/diceserver.cpp (limited to 'src/bin/webserver/diceserver.cpp') diff --git a/src/bin/webserver/diceserver.cpp b/src/bin/webserver/diceserver.cpp new file mode 100644 index 0000000..a3f094d --- /dev/null +++ b/src/bin/webserver/diceserver.cpp @@ -0,0 +1,237 @@ +#include "diceserver.h" +#include "qhttp/src/qhttpfwd.hpp" +#include "qhttp/src/qhttpserver.hpp" +#include "qhttp/src/qhttpserverrequest.hpp" +#include "qhttp/src/qhttpserverresponse.hpp" +#include +#include + +DiceServer::DiceServer(int port) : QObject(), m_diceParser(new DiceParser()) +{ + m_diceParser->setPathToHelp( + "Documentation"); + // using namespace ; + m_server= new qhttp::server::QHttpServer(this); + m_server->listen( // listening on 0.0.0.0:8080 + QHostAddress::Any, port, [=](qhttp::server::QHttpRequest* req, qhttp::server::QHttpResponse* res) { + req->collectData(1024); + + // qhttp::THeaderHash hash = req->headers(); + // qDebug() << hash << res->headers() << qhttp::Stringify::toString(req->method()) << + // qPrintable(req->url().toString()) << req->collectedData().constData(); + QString getArg= req->url().toString(); + getArg= getArg.replace("/?", ""); + QStringList args= getArg.split('&'); + QHash m_hashArgs; + for(auto argument : args) + { + QStringList keyValue= argument.split('='); + if(keyValue.size() == 2) + { + m_hashArgs.insert(keyValue[0], keyValue[1]); + } + } + + if(m_hashArgs.contains("cmd")) + { + qDebug() << QUrl::fromPercentEncoding(m_hashArgs["cmd"].toLocal8Bit()); + QString result= startDiceParsing(QUrl::fromPercentEncoding(m_hashArgs["cmd"].toLocal8Bit())); + qDebug() << result; + + res->setStatusCode(qhttp::ESTATUS_OK); + res->addHeader("Access-Control-Allow-Origin", "*"); + res->addHeader("Access-Control-Allow-Methods", "POST, GET, OPTIONS"); + res->addHeader("Access-Control-Allow-Headers", "x-requested-with"); + + QString html("\n" + "\n" + "\n" + " \n" + " Rolisteam Dice System Webservice\n" + " " + "\n" + "\n" + "%1\n" + "\n" + "\n"); + + res->end(html.arg(result).toLocal8Bit()); + } + else + { + res->setStatusCode(qhttp::ESTATUS_OK); + res->end("No Command found!\n"); + } + }); + if(!m_server->isListening()) + { + qDebug() << "failed to listen"; + } + else + { + qDebug() << "Server is On!!"; + } +} + +DiceServer::~DiceServer() +{ + qDebug() << "destructor"; +} +QString DiceServer::diceToText(ExportedDiceResult& dice, bool highlight, bool homogeneous) +{ + QStringList resultGlobal; + foreach(int face, dice.keys()) + { + QStringList result; + QStringList currentStreak; + QList allStreakList; + ListDiceResult diceResult= dice.value(face); + bool previousHighlight= false; + QString previousColor; + QString patternColor(""); + foreach(HighLightDice tmp, diceResult) + { + if(previousColor != tmp.getColor()) + { + if(!currentStreak.isEmpty()) + { + QStringList list; + list << patternColor + currentStreak.join(',') + ""; + allStreakList.append(list); + currentStreak.clear(); + } + if(tmp.getColor().isEmpty()) + { + patternColor= QStringLiteral(""); + } + else + { + patternColor= QStringLiteral("").arg(tmp.getColor()); + } + } + QStringList diceListStr; + if((previousHighlight) && (!tmp.isHighlighted())) + { + if(!currentStreak.isEmpty()) + { + QStringList list; + list << patternColor + currentStreak.join(',') + ""; + allStreakList.append(list); + currentStreak.clear(); + } + } + else if((!previousHighlight) && (tmp.isHighlighted())) + { + if(!currentStreak.isEmpty()) + { + QStringList list; + list << currentStreak.join(','); + allStreakList.append(list); + currentStreak.clear(); + } + } + previousHighlight= tmp.isHighlighted(); + previousColor= tmp.getColor(); + for(int i= 0; i < tmp.getResult().size(); ++i) + { + qint64 dievalue= tmp.getResult()[i]; + diceListStr << QString::number(dievalue); + } + if(diceListStr.size() > 1) + { + QString first= diceListStr.takeFirst(); + first= QString("%1 [%2]").arg(first).arg(diceListStr.join(',')); + diceListStr.clear(); + diceListStr << first; + } + currentStreak << diceListStr.join(' '); + } + + if(previousHighlight) + { + QStringList list; + list << patternColor + currentStreak.join(',') + ""; + allStreakList.append(list); + } + else + { + if(!currentStreak.isEmpty()) + { + QStringList list; + list << currentStreak.join(','); + allStreakList.append(list); + } + } + foreach(QStringList a, allStreakList) + { + result << a; + } + if(dice.keys().size() > 1) + { + resultGlobal << QString(" d%2:(%1)").arg(result.join(",")).arg(face); + } + else + { + resultGlobal << result.join(","); + } + } + return resultGlobal.join(""); +} + +QString DiceServer::startDiceParsing(QString cmd) +{ + QString result(""); + bool highlight= true; + if(m_diceParser->parseLine(cmd)) + { + m_diceParser->Start(); + if(!m_diceParser->getErrorMap().isEmpty()) + { + result+= "Error:" + m_diceParser->humanReadableError() + "
"; + } + else + { + ExportedDiceResult list; + bool homogeneous= true; + m_diceParser->getLastDiceResult(list, homogeneous); + QString diceText= diceToText(list, highlight, homogeneous); + QString scalarText; + QString str; + + if(m_diceParser->hasIntegerResultNotInFirst()) + { + scalarText= QString("%1").arg(m_diceParser->getLastIntegerResult()); + } + else if(!list.isEmpty()) + { + scalarText= QString("%1").arg(m_diceParser->getSumOfDiceResult()); + } + if(highlight) + { + str= QString("Result: %1, details:[%3 (%2)]") + .arg(scalarText) + .arg(diceText) + .arg(m_diceParser->getDiceCommand()); + } + else + { + str= QString("Result: %1, details:[%3 (%2)]") + .arg(scalarText) + .arg(diceText) + .arg(m_diceParser->getDiceCommand()); + } + + if(m_diceParser->hasStringResult()) + { + str= m_diceParser->getStringResult(); + } + result+= str + "
"; + } + } + else + { + result+= "Error:" + m_diceParser->humanReadableError() + "
"; + } + + return result; +} -- cgit v1.2.3-70-g09d2