9#include <Cutelyst/Application>
10#include <Cutelyst/Request>
11#include <Cutelyst/Response>
15#include <QLoggingCategory>
17Q_LOGGING_CATEGORY(C_SERVER_SM,
"cutelyst.server.staticmap", QtWarningMsg)
20using namespace Qt::Literals::StringLiterals;
34void StaticMap::addStaticMap(
const QString &mountPoint,
const QString &path,
bool append)
36 QString mp = mountPoint;
37 if (!mp.startsWith(u
'/')) {
41 qCInfo(C_SERVER_SM) <<
"added mapping for" << mp <<
"=>" << path;
43 m_staticMaps.push_back({mp, path, append});
44 std::ranges::sort(m_staticMaps, [](
const MountPoint &a,
const MountPoint &b) ->
bool {
45 return a.mountPoint.size() < b.mountPoint.size();
55 const QString path = c->
req()->path();
56 for (
const MountPoint &mp : m_staticMaps) {
57 if (path.startsWith(mp.mountPoint)) {
58 if (tryToServeFile(c, mp, path)) {
68 QString localPath = path;
70 localPath = path.mid(mp.mountPoint.size());
72 while (localPath.startsWith(u
'/')) {
73 localPath.remove(0, 1);
77 QString absFilePath = dir.absoluteFilePath(localPath);
78 if (!QFile::exists(absFilePath)) {
82 return serveFile(c, absFilePath);
88 const QDateTime currentDateTime = QFileInfo(filename).lastModified();
90 res->setStatus(Response::NotModified);
94 auto file =
new QFile(filename);
95 if (file->open(QFile::ReadOnly)) {
96 qCDebug(C_SERVER_SM) <<
"Serving" << filename;
97 Headers &headers = res->headers();
103 QMimeType mimeType = m_db.mimeTypeForFile(filename, QMimeDatabase::MatchExtension);
104 if (mimeType.isValid()) {
110 headers.
setHeader(
"Cache-Control"_ba,
"public"_ba);
115 qCWarning(C_SERVER_SM) <<
"Could not serve" << filename << file->errorString();
120#include "moc_staticmap.cpp"
The Cutelyst application.
void beforePrepareAction(Cutelyst::Context *c, bool *skipMethod)
Response * response() const noexcept
Base class for Cutelyst Plugins.
Headers headers() const noexcept
virtual bool setup(Cutelyst::Application *app) override
The Cutelyst namespace holds all public Cutelyst API.