Respect 'private_forward_name'

This commit is contained in:
Eduard Kuzmenko 2022-02-13 13:29:17 +04:00
parent dd4a7ab617
commit 85423a9f76

View File

@ -17,7 +17,7 @@ import { createPosterForVideo } from "../../helpers/files";
import { copy, deepEqual, getObjectKeysAndSort } from "../../helpers/object"; import { copy, deepEqual, getObjectKeysAndSort } from "../../helpers/object";
import { randomLong } from "../../helpers/random"; import { randomLong } from "../../helpers/random";
import { splitStringByLength, limitSymbols, escapeRegExp } from "../../helpers/string"; import { splitStringByLength, limitSymbols, escapeRegExp } from "../../helpers/string";
import { Chat, ChatFull, Dialog as MTDialog, DialogPeer, DocumentAttribute, InputMedia, InputMessage, InputPeerNotifySettings, InputSingleMedia, Message, MessageAction, MessageEntity, MessageFwdHeader, MessageMedia, MessageReplies, MessageReplyHeader, MessagesDialogs, MessagesFilter, MessagesMessages, MethodDeclMap, NotifyPeer, PeerNotifySettings, PhotoSize, SendMessageAction, Update, Photo, Updates, ReplyMarkup, InputPeer, InputPhoto, InputDocument, InputGeoPoint, WebPage, GeoPoint, ReportReason, MessagesGetDialogs, InputChannel, InputDialogPeer, ReactionCount, MessagePeerReaction, MessagesSearchCounter } from "../../layer"; import { Chat, ChatFull, Dialog as MTDialog, DialogPeer, DocumentAttribute, InputMedia, InputMessage, InputPeerNotifySettings, InputSingleMedia, Message, MessageAction, MessageEntity, MessageFwdHeader, MessageMedia, MessageReplies, MessageReplyHeader, MessagesDialogs, MessagesFilter, MessagesMessages, MethodDeclMap, NotifyPeer, PeerNotifySettings, PhotoSize, SendMessageAction, Update, Photo, Updates, ReplyMarkup, InputPeer, InputPhoto, InputDocument, InputGeoPoint, WebPage, GeoPoint, ReportReason, MessagesGetDialogs, InputChannel, InputDialogPeer, ReactionCount, MessagePeerReaction, MessagesSearchCounter, Peer } from "../../layer";
import { InvokeApiOptions } from "../../types"; import { InvokeApiOptions } from "../../types";
import I18n, { FormatterArguments, i18n, join, langPack, LangPackKey, UNSUPPORTED_LANG_PACK_KEY, _i18n } from "../langPack"; import I18n, { FormatterArguments, i18n, join, langPack, LangPackKey, UNSUPPORTED_LANG_PACK_KEY, _i18n } from "../langPack";
import { logger, LogTypes } from "../logger"; import { logger, LogTypes } from "../logger";
@ -1571,7 +1571,8 @@ export class AppMessagesManager {
private generateForwardHeader(peerId: PeerId, originalMessage: Message.message) { private generateForwardHeader(peerId: PeerId, originalMessage: Message.message) {
const myId = appUsersManager.getSelf().id.toPeerId(); const myId = appUsersManager.getSelf().id.toPeerId();
if(originalMessage.fromId === myId && originalMessage.peerId === myId && !originalMessage.fwd_from) { const fromId = originalMessage.fromId;
if(fromId === myId && originalMessage.peerId === myId && !originalMessage.fwd_from) {
return; return;
} }
@ -1581,13 +1582,25 @@ export class AppMessagesManager {
date: originalMessage.date date: originalMessage.date
}; };
let isUserHidden = false;
if(originalMessage.fwd_from) { if(originalMessage.fwd_from) {
fwdHeader.from_id = originalMessage.fwd_from.from_id; fwdHeader.from_id = originalMessage.fwd_from.from_id;
fwdHeader.from_name = originalMessage.fwd_from.from_name; fwdHeader.from_name = originalMessage.fwd_from.from_name;
fwdHeader.post_author = originalMessage.fwd_from.post_author; fwdHeader.post_author = originalMessage.fwd_from.post_author;
} else { } else {
fwdHeader.from_id = appPeersManager.getOutputPeer(originalMessage.fromId);
fwdHeader.post_author = originalMessage.post_author; fwdHeader.post_author = originalMessage.post_author;
if(fromId.isUser()) {
const userFull = appProfileManager.getCachedFullUser(fromId.toUserId());
if(userFull?.private_forward_name) {
fwdHeader.from_name = userFull.private_forward_name;
isUserHidden = true;
}
}
if(!isUserHidden) {
fwdHeader.from_id = appPeersManager.getOutputPeer(fromId);
}
} }
if(appPeersManager.isBroadcast(originalMessage.peerId)) { if(appPeersManager.isBroadcast(originalMessage.peerId)) {
@ -1598,8 +1611,7 @@ export class AppMessagesManager {
fwdHeader.channel_post = originalMessage.id; fwdHeader.channel_post = originalMessage.id;
} }
// * there is no way to detect whether user profile is hidden if(peerId === myId && !isUserHidden) {
if(peerId === myId) {
fwdHeader.saved_from_msg_id = originalMessage.id; fwdHeader.saved_from_msg_id = originalMessage.id;
fwdHeader.saved_from_peer = appPeersManager.getOutputPeer(originalMessage.peerId); fwdHeader.saved_from_peer = appPeersManager.getOutputPeer(originalMessage.peerId);
} }
@ -1972,6 +1984,10 @@ export class AppMessagesManager {
if(!options.dropAuthor) { if(!options.dropAuthor) {
message.fwd_from = this.generateForwardHeader(peerId, originalMessage); message.fwd_from = this.generateForwardHeader(peerId, originalMessage);
keys.push('views', 'forwards'); keys.push('views', 'forwards');
if(message.fwd_from.from_name) {
message
}
} }
if(!options.dropCaptions || !originalMessage.media) { if(!options.dropCaptions || !originalMessage.media) {