Moved preparing MTPInputMedia to separate file.
This commit is contained in:
parent
7dd9adb934
commit
c350e33dd8
|
@ -215,6 +215,8 @@ PRIVATE
|
||||||
api/api_common.h
|
api/api_common.h
|
||||||
api/api_hash.cpp
|
api/api_hash.cpp
|
||||||
api/api_hash.h
|
api/api_hash.h
|
||||||
|
api/api_media.cpp
|
||||||
|
api/api_media.h
|
||||||
api/api_self_destruct.cpp
|
api/api_self_destruct.cpp
|
||||||
api/api_self_destruct.h
|
api/api_self_destruct.h
|
||||||
api/api_send_progress.cpp
|
api/api_send_progress.cpp
|
||||||
|
|
|
@ -0,0 +1,107 @@
|
||||||
|
/*
|
||||||
|
This file is part of Telegram Desktop,
|
||||||
|
the official desktop application for the Telegram messaging service.
|
||||||
|
|
||||||
|
For license and copyright information please follow this link:
|
||||||
|
https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL
|
||||||
|
*/
|
||||||
|
#include "api/api_media.h"
|
||||||
|
|
||||||
|
#include "data/data_document.h"
|
||||||
|
#include "history/history_item.h"
|
||||||
|
|
||||||
|
namespace Api {
|
||||||
|
namespace {
|
||||||
|
|
||||||
|
MTPVector<MTPDocumentAttribute> ComposeSendingDocumentAttributes(
|
||||||
|
not_null<DocumentData*> document) {
|
||||||
|
const auto filenameAttribute = MTP_documentAttributeFilename(
|
||||||
|
MTP_string(document->filename()));
|
||||||
|
const auto dimensions = document->dimensions;
|
||||||
|
auto attributes = QVector<MTPDocumentAttribute>(1, filenameAttribute);
|
||||||
|
if (dimensions.width() > 0 && dimensions.height() > 0) {
|
||||||
|
const auto duration = document->getDuration();
|
||||||
|
if (duration >= 0 && !document->hasMimeType(qstr("image/gif"))) {
|
||||||
|
auto flags = MTPDdocumentAttributeVideo::Flags(0);
|
||||||
|
using VideoFlag = MTPDdocumentAttributeVideo::Flag;
|
||||||
|
if (document->isVideoMessage()) {
|
||||||
|
flags |= VideoFlag::f_round_message;
|
||||||
|
}
|
||||||
|
if (document->supportsStreaming()) {
|
||||||
|
flags |= VideoFlag::f_supports_streaming;
|
||||||
|
}
|
||||||
|
attributes.push_back(MTP_documentAttributeVideo(
|
||||||
|
MTP_flags(flags),
|
||||||
|
MTP_int(duration),
|
||||||
|
MTP_int(dimensions.width()),
|
||||||
|
MTP_int(dimensions.height())));
|
||||||
|
} else {
|
||||||
|
attributes.push_back(MTP_documentAttributeImageSize(
|
||||||
|
MTP_int(dimensions.width()),
|
||||||
|
MTP_int(dimensions.height())));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (document->type == AnimatedDocument) {
|
||||||
|
attributes.push_back(MTP_documentAttributeAnimated());
|
||||||
|
} else if (document->type == StickerDocument && document->sticker()) {
|
||||||
|
attributes.push_back(MTP_documentAttributeSticker(
|
||||||
|
MTP_flags(0),
|
||||||
|
MTP_string(document->sticker()->alt),
|
||||||
|
document->sticker()->set,
|
||||||
|
MTPMaskCoords()));
|
||||||
|
} else if (const auto song = document->song()) {
|
||||||
|
const auto flags = MTPDdocumentAttributeAudio::Flag::f_title
|
||||||
|
| MTPDdocumentAttributeAudio::Flag::f_performer;
|
||||||
|
attributes.push_back(MTP_documentAttributeAudio(
|
||||||
|
MTP_flags(flags),
|
||||||
|
MTP_int(song->duration),
|
||||||
|
MTP_string(song->title),
|
||||||
|
MTP_string(song->performer),
|
||||||
|
MTPstring()));
|
||||||
|
} else if (const auto voice = document->voice()) {
|
||||||
|
const auto flags = MTPDdocumentAttributeAudio::Flag::f_voice
|
||||||
|
| MTPDdocumentAttributeAudio::Flag::f_waveform;
|
||||||
|
attributes.push_back(MTP_documentAttributeAudio(
|
||||||
|
MTP_flags(flags),
|
||||||
|
MTP_int(voice->duration),
|
||||||
|
MTPstring(),
|
||||||
|
MTPstring(),
|
||||||
|
MTP_bytes(documentWaveformEncode5bit(voice->waveform))));
|
||||||
|
}
|
||||||
|
return MTP_vector<MTPDocumentAttribute>(attributes);
|
||||||
|
}
|
||||||
|
|
||||||
|
} // namespace
|
||||||
|
|
||||||
|
MTPInputMedia PrepareUploadedPhoto(const MTPInputFile &file) {
|
||||||
|
return MTP_inputMediaUploadedPhoto(
|
||||||
|
MTP_flags(0),
|
||||||
|
file,
|
||||||
|
MTPVector<MTPInputDocument>(),
|
||||||
|
MTP_int(0));
|
||||||
|
}
|
||||||
|
|
||||||
|
MTPInputMedia PrepareUploadedDocument(
|
||||||
|
not_null<HistoryItem*> item,
|
||||||
|
const MTPInputFile &file,
|
||||||
|
const std::optional<MTPInputFile> &thumb) {
|
||||||
|
if (!item || !item->media() || !item->media()->document()) {
|
||||||
|
return MTP_inputMediaEmpty();
|
||||||
|
}
|
||||||
|
const auto emptyFlag = MTPDinputMediaUploadedDocument::Flags(0);
|
||||||
|
using DocFlags = MTPDinputMediaUploadedDocument::Flag;
|
||||||
|
const auto flags = emptyFlag
|
||||||
|
| (thumb ? DocFlags::f_thumb : emptyFlag)
|
||||||
|
| (item->groupId() ? DocFlags::f_nosound_video : emptyFlag);
|
||||||
|
const auto document = item->media()->document();
|
||||||
|
return MTP_inputMediaUploadedDocument(
|
||||||
|
MTP_flags(flags),
|
||||||
|
file,
|
||||||
|
thumb.value_or(MTPInputFile()),
|
||||||
|
MTP_string(document->mimeString()),
|
||||||
|
ComposeSendingDocumentAttributes(document),
|
||||||
|
MTPVector<MTPInputDocument>(),
|
||||||
|
MTP_int(0));
|
||||||
|
}
|
||||||
|
|
||||||
|
} // namespace Api
|
|
@ -0,0 +1,21 @@
|
||||||
|
/*
|
||||||
|
This file is part of Telegram Desktop,
|
||||||
|
the official desktop application for the Telegram messaging service.
|
||||||
|
|
||||||
|
For license and copyright information please follow this link:
|
||||||
|
https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL
|
||||||
|
*/
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
class HistoryItem;
|
||||||
|
|
||||||
|
namespace Api {
|
||||||
|
|
||||||
|
MTPInputMedia PrepareUploadedPhoto(const MTPInputFile &file);
|
||||||
|
|
||||||
|
MTPInputMedia PrepareUploadedDocument(
|
||||||
|
not_null<HistoryItem*> item,
|
||||||
|
const MTPInputFile &file,
|
||||||
|
const std::optional<MTPInputFile> &thumb);
|
||||||
|
|
||||||
|
} // namespace Api
|
|
@ -8,6 +8,7 @@ https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL
|
||||||
#include "apiwrap.h"
|
#include "apiwrap.h"
|
||||||
|
|
||||||
#include "api/api_hash.h"
|
#include "api/api_hash.h"
|
||||||
|
#include "api/api_media.h"
|
||||||
#include "api/api_sending.h"
|
#include "api/api_sending.h"
|
||||||
#include "api/api_text_entities.h"
|
#include "api/api_text_entities.h"
|
||||||
#include "api/api_self_destruct.h"
|
#include "api/api_self_destruct.h"
|
||||||
|
@ -111,63 +112,6 @@ using PhotoFileLocationId = Data::PhotoFileLocationId;
|
||||||
using DocumentFileLocationId = Data::DocumentFileLocationId;
|
using DocumentFileLocationId = Data::DocumentFileLocationId;
|
||||||
using UpdatedFileReferences = Data::UpdatedFileReferences;
|
using UpdatedFileReferences = Data::UpdatedFileReferences;
|
||||||
|
|
||||||
MTPVector<MTPDocumentAttribute> ComposeSendingDocumentAttributes(
|
|
||||||
not_null<DocumentData*> document) {
|
|
||||||
const auto filenameAttribute = MTP_documentAttributeFilename(
|
|
||||||
MTP_string(document->filename()));
|
|
||||||
const auto dimensions = document->dimensions;
|
|
||||||
auto attributes = QVector<MTPDocumentAttribute>(1, filenameAttribute);
|
|
||||||
if (dimensions.width() > 0 && dimensions.height() > 0) {
|
|
||||||
const auto duration = document->getDuration();
|
|
||||||
if (duration >= 0 && !document->hasMimeType(qstr("image/gif"))) {
|
|
||||||
auto flags = MTPDdocumentAttributeVideo::Flags(0);
|
|
||||||
if (document->isVideoMessage()) {
|
|
||||||
flags |= MTPDdocumentAttributeVideo::Flag::f_round_message;
|
|
||||||
}
|
|
||||||
if (document->supportsStreaming()) {
|
|
||||||
flags |= MTPDdocumentAttributeVideo::Flag::f_supports_streaming;
|
|
||||||
}
|
|
||||||
attributes.push_back(MTP_documentAttributeVideo(
|
|
||||||
MTP_flags(flags),
|
|
||||||
MTP_int(duration),
|
|
||||||
MTP_int(dimensions.width()),
|
|
||||||
MTP_int(dimensions.height())));
|
|
||||||
} else {
|
|
||||||
attributes.push_back(MTP_documentAttributeImageSize(
|
|
||||||
MTP_int(dimensions.width()),
|
|
||||||
MTP_int(dimensions.height())));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (document->type == AnimatedDocument) {
|
|
||||||
attributes.push_back(MTP_documentAttributeAnimated());
|
|
||||||
} else if (document->type == StickerDocument && document->sticker()) {
|
|
||||||
attributes.push_back(MTP_documentAttributeSticker(
|
|
||||||
MTP_flags(0),
|
|
||||||
MTP_string(document->sticker()->alt),
|
|
||||||
document->sticker()->set,
|
|
||||||
MTPMaskCoords()));
|
|
||||||
} else if (const auto song = document->song()) {
|
|
||||||
const auto flags = MTPDdocumentAttributeAudio::Flag::f_title
|
|
||||||
| MTPDdocumentAttributeAudio::Flag::f_performer;
|
|
||||||
attributes.push_back(MTP_documentAttributeAudio(
|
|
||||||
MTP_flags(flags),
|
|
||||||
MTP_int(song->duration),
|
|
||||||
MTP_string(song->title),
|
|
||||||
MTP_string(song->performer),
|
|
||||||
MTPstring()));
|
|
||||||
} else if (const auto voice = document->voice()) {
|
|
||||||
const auto flags = MTPDdocumentAttributeAudio::Flag::f_voice
|
|
||||||
| MTPDdocumentAttributeAudio::Flag::f_waveform;
|
|
||||||
attributes.push_back(MTP_documentAttributeAudio(
|
|
||||||
MTP_flags(flags),
|
|
||||||
MTP_int(voice->duration),
|
|
||||||
MTPstring(),
|
|
||||||
MTPstring(),
|
|
||||||
MTP_bytes(documentWaveformEncode5bit(voice->waveform))));
|
|
||||||
}
|
|
||||||
return MTP_vector<MTPDocumentAttribute>(attributes);
|
|
||||||
}
|
|
||||||
|
|
||||||
} // namespace
|
} // namespace
|
||||||
|
|
||||||
MTPInputPrivacyKey ApiWrap::Privacy::Input(Key key) {
|
MTPInputPrivacyKey ApiWrap::Privacy::Input(Key key) {
|
||||||
|
@ -4339,11 +4283,7 @@ void ApiWrap::sendUploadedPhoto(
|
||||||
const MTPInputFile &file,
|
const MTPInputFile &file,
|
||||||
Api::SendOptions options) {
|
Api::SendOptions options) {
|
||||||
if (const auto item = _session->data().message(localId)) {
|
if (const auto item = _session->data().message(localId)) {
|
||||||
const auto media = MTP_inputMediaUploadedPhoto(
|
const auto media = Api::PrepareUploadedPhoto(file);
|
||||||
MTP_flags(0),
|
|
||||||
file,
|
|
||||||
MTPVector<MTPInputDocument>(),
|
|
||||||
MTP_int(0));
|
|
||||||
if (const auto groupId = item->groupId()) {
|
if (const auto groupId = item->groupId()) {
|
||||||
uploadAlbumMedia(item, groupId, media);
|
uploadAlbumMedia(item, groupId, media);
|
||||||
} else {
|
} else {
|
||||||
|
@ -4358,31 +4298,17 @@ void ApiWrap::sendUploadedDocument(
|
||||||
const std::optional<MTPInputFile> &thumb,
|
const std::optional<MTPInputFile> &thumb,
|
||||||
Api::SendOptions options) {
|
Api::SendOptions options) {
|
||||||
if (const auto item = _session->data().message(localId)) {
|
if (const auto item = _session->data().message(localId)) {
|
||||||
auto media = item->media();
|
if (!item->media() || !item->media()->document()) {
|
||||||
if (auto document = media ? media->document() : nullptr) {
|
return;
|
||||||
|
}
|
||||||
|
const auto media = Api::PrepareUploadedDocument(item, file, thumb);
|
||||||
const auto groupId = item->groupId();
|
const auto groupId = item->groupId();
|
||||||
const auto flags = MTPDinputMediaUploadedDocument::Flags(0)
|
|
||||||
| (thumb
|
|
||||||
? MTPDinputMediaUploadedDocument::Flag::f_thumb
|
|
||||||
: MTPDinputMediaUploadedDocument::Flag(0))
|
|
||||||
| (groupId
|
|
||||||
? MTPDinputMediaUploadedDocument::Flag::f_nosound_video
|
|
||||||
: MTPDinputMediaUploadedDocument::Flag(0));
|
|
||||||
const auto media = MTP_inputMediaUploadedDocument(
|
|
||||||
MTP_flags(flags),
|
|
||||||
file,
|
|
||||||
thumb ? *thumb : MTPInputFile(),
|
|
||||||
MTP_string(document->mimeString()),
|
|
||||||
ComposeSendingDocumentAttributes(document),
|
|
||||||
MTPVector<MTPInputDocument>(),
|
|
||||||
MTP_int(0));
|
|
||||||
if (groupId) {
|
if (groupId) {
|
||||||
uploadAlbumMedia(item, groupId, media);
|
uploadAlbumMedia(item, groupId, media);
|
||||||
} else {
|
} else {
|
||||||
sendMedia(item, media, options);
|
sendMedia(item, media, options);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void ApiWrap::editUploadedFile(
|
void ApiWrap::editUploadedFile(
|
||||||
|
@ -4409,43 +4335,9 @@ void ApiWrap::editUploadedFile(
|
||||||
flagsEditMsg |= MTPmessages_EditMessage::Flag::f_entities;
|
flagsEditMsg |= MTPmessages_EditMessage::Flag::f_entities;
|
||||||
flagsEditMsg |= MTPmessages_EditMessage::Flag::f_media;
|
flagsEditMsg |= MTPmessages_EditMessage::Flag::f_media;
|
||||||
|
|
||||||
const auto media = [&]() -> std::optional<MTPInputMedia> {
|
const auto media = isDocument
|
||||||
if (!isDocument) {
|
? Api::PrepareUploadedDocument(item, file, thumb)
|
||||||
if (!item->media()->photo()) {
|
: Api::PrepareUploadedPhoto(file);
|
||||||
return std::nullopt;
|
|
||||||
}
|
|
||||||
return MTP_inputMediaUploadedPhoto(
|
|
||||||
MTP_flags(0),
|
|
||||||
file,
|
|
||||||
MTPVector<MTPInputDocument>(),
|
|
||||||
MTP_int(0));
|
|
||||||
}
|
|
||||||
|
|
||||||
const auto document = item->media()->document();
|
|
||||||
if (!document) {
|
|
||||||
return std::nullopt;
|
|
||||||
}
|
|
||||||
|
|
||||||
const auto flags = MTPDinputMediaUploadedDocument::Flags(0)
|
|
||||||
| (thumb
|
|
||||||
? MTPDinputMediaUploadedDocument::Flag::f_thumb
|
|
||||||
: MTPDinputMediaUploadedDocument::Flag(0))
|
|
||||||
| (item->groupId()
|
|
||||||
? MTPDinputMediaUploadedDocument::Flag::f_nosound_video
|
|
||||||
: MTPDinputMediaUploadedDocument::Flag(0));
|
|
||||||
return MTP_inputMediaUploadedDocument(
|
|
||||||
MTP_flags(flags),
|
|
||||||
file,
|
|
||||||
thumb ? *thumb : MTPInputFile(),
|
|
||||||
MTP_string(document->mimeString()),
|
|
||||||
ComposeSendingDocumentAttributes(document),
|
|
||||||
MTPVector<MTPInputDocument>(),
|
|
||||||
MTP_int(0));
|
|
||||||
}();
|
|
||||||
|
|
||||||
if (!media) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
const auto peer = item->history()->peer;
|
const auto peer = item->history()->peer;
|
||||||
request(MTPmessages_EditMessage(
|
request(MTPmessages_EditMessage(
|
||||||
|
@ -4453,7 +4345,7 @@ void ApiWrap::editUploadedFile(
|
||||||
peer->input,
|
peer->input,
|
||||||
MTP_int(item->id),
|
MTP_int(item->id),
|
||||||
MTP_string(item->originalText().text),
|
MTP_string(item->originalText().text),
|
||||||
*media,
|
media,
|
||||||
MTPReplyMarkup(),
|
MTPReplyMarkup(),
|
||||||
sentEntities,
|
sentEntities,
|
||||||
MTP_int(0) // schedule_date
|
MTP_int(0) // schedule_date
|
||||||
|
|
Loading…
Reference in New Issue