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
|
// 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)
: mimeType(QMimeDatabase().mimeTypeForFile(fi))
, url(QUrl::fromLocalFile(fi.filePath()))
, payloadSize(fi.size())
, originalName(fi.fileName())
{
Q_ASSERT(fi.isFile());
}
FileInfo::FileInfo(QUrl u, qint64 payloadSize, const QMimeType& mimeType,
Omittable<EncryptedFile> file, QString originalFilename)
: mimeType(mimeType)
, url(move(u))
, payloadSize(payloadSize)
, originalName(move(originalFilename))
, file(file)
{
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(QUrl mxcUrl, const QJsonObject& infoJson,
const Omittable<EncryptedFile> &file,
QString originalFilename)
: originalInfoJson(infoJson)
, mimeType(
QMimeDatabase().mimeTypeForName(infoJson["mimetype"_ls].toString()))
, url(move(mxcUrl))
, payloadSize(fromJson<qint64>(infoJson["size"_ls]))
, originalName(move(originalFilename))
, file(file)
{
if(url.isEmpty() && file.has_value()) {
url = file->url;
}
if (!mimeType.isValid())
mimeType = QMimeDatabase().mimeTypeForData(QByteArray());
}
bool FileInfo::isValid() const
{
return url.scheme() == "mxc"
&& (url.authority() + url.path()).count('/') == 1;
}
void FileInfo::fillInfoJson(QJsonObject* infoJson) const
{
Q_ASSERT(infoJson);
if (payloadSize != -1)
infoJson->insert(QStringLiteral("size"), payloadSize);
if (mimeType.isValid())
infoJson->insert(QStringLiteral("mimetype"), mimeType.name());
//TODO add encryptedfile
}
ImageInfo::ImageInfo(const QFileInfo& fi, QSize imageSize)
: FileInfo(fi), imageSize(imageSize)
{}
ImageInfo::ImageInfo(const QUrl& mxcUrl, qint64 fileSize, const QMimeType& type,
QSize imageSize, const Omittable<EncryptedFile> &file, const QString& originalFilename)
: FileInfo(mxcUrl, fileSize, type, file, originalFilename)
, imageSize(imageSize)
{}
ImageInfo::ImageInfo(const QUrl& mxcUrl, const QJsonObject& infoJson,
const Omittable<EncryptedFile> &file,
const QString& originalFilename)
: FileInfo(mxcUrl, infoJson, file, originalFilename)
, imageSize(infoJson["w"_ls].toInt(), infoJson["h"_ls].toInt())
{}
void ImageInfo::fillInfoJson(QJsonObject* infoJson) const
{
FileInfo::fillInfoJson(infoJson);
if (imageSize.width() != -1)
infoJson->insert(QStringLiteral("w"), imageSize.width());
if (imageSize.height() != -1)
infoJson->insert(QStringLiteral("h"), imageSize.height());
}
Thumbnail::Thumbnail(const QJsonObject& infoJson, const Omittable<EncryptedFile> &file)
: ImageInfo(QUrl(infoJson["thumbnail_url"_ls].toString()),
infoJson["thumbnail_info"_ls].toObject(),
file)
{}
void Thumbnail::fillInfoJson(QJsonObject* infoJson) const
{
if (url.isValid())
infoJson->insert(QStringLiteral("thumbnail_url"), url.toString());
if (!imageSize.isEmpty())
infoJson->insert(QStringLiteral("thumbnail_info"),
toInfoJson<ImageInfo>(*this));
}
|