1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
|
// SPDX-FileCopyrightText: 2017 Kitsune Ral <kitsune-ral@users.sf.net>
// SPDX-License-Identifier: LGPL-2.1-or-later
#include "eventcontent.h"
#include "converters.h"
#include "logging.h"
#include <QtCore/QMimeDatabase>
#include <QtCore/QFileInfo>
using namespace Quotient::EventContent;
using std::move;
QJsonObject Base::toJson() const
{
QJsonObject o;
fillJson(o);
return o;
}
FileInfo::FileInfo(const QFileInfo& fi)
: source(QUrl::fromLocalFile(fi.filePath())),
mimeType(QMimeDatabase().mimeTypeForFile(fi)),
payloadSize(fi.size()),
originalName(fi.fileName())
{
Q_ASSERT(fi.isFile());
}
FileInfo::FileInfo(FileSourceInfo sourceInfo, qint64 payloadSize,
const QMimeType& mimeType, QString originalFilename)
: source(move(sourceInfo))
, mimeType(mimeType)
, payloadSize(payloadSize)
, originalName(move(originalFilename))
{
if (!isValid())
qCWarning(MESSAGES)
<< "To client developers: using FileInfo(QUrl, qint64, ...) "
"constructor for non-mxc resources is deprecated since Quotient "
"0.7; for local resources, use FileInfo(QFileInfo) instead";
}
FileInfo::FileInfo(FileSourceInfo sourceInfo, const QJsonObject& infoJson,
QString originalFilename)
: source(move(sourceInfo))
, originalInfoJson(infoJson)
, mimeType(
QMimeDatabase().mimeTypeForName(infoJson["mimetype"_ls].toString()))
, payloadSize(fromJson<qint64>(infoJson["size"_ls]))
, originalName(move(originalFilename))
{
if (!mimeType.isValid())
mimeType = QMimeDatabase().mimeTypeForData(QByteArray());
}
bool FileInfo::isValid() const
{
const auto& u = url();
return u.scheme() == "mxc" && (u.authority() + u.path()).count('/') == 1;
}
QUrl FileInfo::url() const
{
return getUrlFromSourceInfo(source);
}
QJsonObject Quotient::EventContent::toInfoJson(const FileInfo& info)
{
QJsonObject infoJson;
if (info.payloadSize != -1)
infoJson.insert(QStringLiteral("size"), info.payloadSize);
if (info.mimeType.isValid())
infoJson.insert(QStringLiteral("mimetype"), info.mimeType.name());
return infoJson;
}
ImageInfo::ImageInfo(const QFileInfo& fi, QSize imageSize)
: FileInfo(fi), imageSize(imageSize)
{}
ImageInfo::ImageInfo(FileSourceInfo sourceInfo, qint64 fileSize,
const QMimeType& type, QSize imageSize,
const QString& originalFilename)
: FileInfo(move(sourceInfo), fileSize, type, originalFilename)
, imageSize(imageSize)
{}
ImageInfo::ImageInfo(FileSourceInfo sourceInfo, const QJsonObject& infoJson,
const QString& originalFilename)
: FileInfo(move(sourceInfo), infoJson, originalFilename)
, imageSize(infoJson["w"_ls].toInt(), infoJson["h"_ls].toInt())
{}
QJsonObject Quotient::EventContent::toInfoJson(const ImageInfo& info)
{
auto infoJson = toInfoJson(static_cast<const FileInfo&>(info));
if (info.imageSize.width() != -1)
infoJson.insert(QStringLiteral("w"), info.imageSize.width());
if (info.imageSize.height() != -1)
infoJson.insert(QStringLiteral("h"), info.imageSize.height());
return infoJson;
}
Thumbnail::Thumbnail(
const QJsonObject& infoJson,
const Omittable<EncryptedFileMetadata>& encryptedFileMetadata)
: ImageInfo(QUrl(infoJson["thumbnail_url"_ls].toString()),
infoJson["thumbnail_info"_ls].toObject())
{
if (encryptedFileMetadata)
source = *encryptedFileMetadata;
}
void Thumbnail::dumpTo(QJsonObject& infoJson) const
{
if (url().isValid())
fillJson(infoJson, { "thumbnail_url"_ls, "thumbnail_file"_ls }, source);
if (!imageSize.isEmpty())
infoJson.insert(QStringLiteral("thumbnail_info"),
toInfoJson(*this));
}
|