diff --git a/TMessagesProj/build.gradle b/TMessagesProj/build.gradle index 0b0ef7a7ea7..2f77da0b6f0 100644 --- a/TMessagesProj/build.gradle +++ b/TMessagesProj/build.gradle @@ -299,7 +299,7 @@ android { } } - defaultConfig.versionCode = 2462 + defaultConfig.versionCode = 2470 applicationVariants.all { variant -> variant.outputs.all { output -> @@ -318,7 +318,7 @@ android { defaultConfig { minSdkVersion 16 targetSdkVersion 30 - versionName "8.2.1" + versionName "8.2.7" vectorDrawables.generatedDensities = ['mdpi', 'hdpi', 'xhdpi', 'xxhdpi'] diff --git a/TMessagesProj/src/main/AndroidManifest.xml b/TMessagesProj/src/main/AndroidManifest.xml index 79376604e48..0d40f1db615 100644 --- a/TMessagesProj/src/main/AndroidManifest.xml +++ b/TMessagesProj/src/main/AndroidManifest.xml @@ -49,6 +49,7 @@ + @@ -66,6 +67,7 @@ + diff --git a/TMessagesProj/src/main/java/org/telegram/messenger/BuildVars.java b/TMessagesProj/src/main/java/org/telegram/messenger/BuildVars.java index 393e4c176f2..524e5ef946d 100644 --- a/TMessagesProj/src/main/java/org/telegram/messenger/BuildVars.java +++ b/TMessagesProj/src/main/java/org/telegram/messenger/BuildVars.java @@ -20,8 +20,8 @@ public class BuildVars { public static boolean USE_CLOUD_STRINGS = true; public static boolean CHECK_UPDATES = true; public static boolean NO_SCOPED_STORAGE = Build.VERSION.SDK_INT <= 29; - public static int BUILD_VERSION = 2466; - public static String BUILD_VERSION_STRING = "8.2.3"; + public static int BUILD_VERSION = 2470; + public static String BUILD_VERSION_STRING = "8.2.7"; public static int APP_ID = 4; public static String APP_HASH = "014b35b6184100b085b0d0572f9b5103"; diff --git a/TMessagesProj/src/main/java/org/telegram/messenger/MediaController.java b/TMessagesProj/src/main/java/org/telegram/messenger/MediaController.java index 538d91e3a6d..4a9cdd5da8a 100644 --- a/TMessagesProj/src/main/java/org/telegram/messenger/MediaController.java +++ b/TMessagesProj/src/main/java/org/telegram/messenger/MediaController.java @@ -3926,6 +3926,7 @@ public static void saveFile(String fullPath, Context context, final int type, fi boolean result = true; if (Build.VERSION.SDK_INT >= 29) { try { + int selectedType = type; ContentValues contentValues = new ContentValues(); String extension = MimeTypeMap.getFileExtensionFromUrl(sourceFile.getAbsolutePath()); String mimeType = null; @@ -3933,7 +3934,15 @@ public static void saveFile(String fullPath, Context context, final int type, fi mimeType = MimeTypeMap.getSingleton().getMimeTypeFromExtension(extension); } Uri uriToInsert = null; - if (type == 0) { + if ((type == 0 || type == 1) && mimeType != null) { + if (mimeType.startsWith("image")) { + selectedType = 0; + } + if (mimeType.startsWith("video")) { + selectedType = 1; + } + } + if (selectedType == 0) { uriToInsert = MediaStore.Images.Media.getContentUri(MediaStore.VOLUME_EXTERNAL_PRIMARY); if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.Q) { File dirDest = new File(Environment.DIRECTORY_PICTURES, "Telegram"); @@ -3941,12 +3950,12 @@ public static void saveFile(String fullPath, Context context, final int type, fi } contentValues.put(MediaStore.Images.Media.DISPLAY_NAME, AndroidUtilities.generateFileName(0, extension)); contentValues.put(MediaStore.Images.Media.MIME_TYPE, mimeType); - } else if (type == 1) { + } else if (selectedType == 1) { File dirDest = new File(Environment.DIRECTORY_MOVIES, "Telegram"); contentValues.put(MediaStore.MediaColumns.RELATIVE_PATH, dirDest + File.separator); uriToInsert = MediaStore.Video.Media.getContentUri(MediaStore.VOLUME_EXTERNAL_PRIMARY); contentValues.put(MediaStore.Video.Media.DISPLAY_NAME, AndroidUtilities.generateFileName(1, extension)); - } else if (type == 2) { + } else if (selectedType == 2) { File dirDest = new File(Environment.DIRECTORY_DOWNLOADS, "Telegram"); contentValues.put(MediaStore.MediaColumns.RELATIVE_PATH, dirDest + File.separator); uriToInsert = MediaStore.Downloads.getContentUri(MediaStore.VOLUME_EXTERNAL_PRIMARY); diff --git a/TMessagesProj/src/main/java/org/telegram/messenger/MessageObject.java b/TMessagesProj/src/main/java/org/telegram/messenger/MessageObject.java index 2a4fd184c7d..4c8361665dd 100644 --- a/TMessagesProj/src/main/java/org/telegram/messenger/MessageObject.java +++ b/TMessagesProj/src/main/java/org/telegram/messenger/MessageObject.java @@ -5967,7 +5967,6 @@ public void checkMediaExistance() { attachPathExists = f.exists(); } if (!attachPathExists) { - File file = FileLoader.getPathToMessage(messageOwner); if (type == 3 && needDrawBluredPreview()) { mediaExists = new File(file.getAbsolutePath() + ".enc").exists(); diff --git a/TMessagesProj/src/main/java/org/telegram/ui/Cells/ChatMessageCell.java b/TMessagesProj/src/main/java/org/telegram/ui/Cells/ChatMessageCell.java index 8e57276bdf9..f98dd1cf35c 100644 --- a/TMessagesProj/src/main/java/org/telegram/ui/Cells/ChatMessageCell.java +++ b/TMessagesProj/src/main/java/org/telegram/ui/Cells/ChatMessageCell.java @@ -1865,7 +1865,11 @@ private boolean checkPhotoImageMotionEvent(MotionEvent event) { } } if (currentMessageObject.type == 12) { - TLRPC.User user = MessagesController.getInstance(currentAccount).getUser(currentMessageObject.messageOwner.media.user_id); + long uid = currentMessageObject.messageOwner.media.user_id; + TLRPC.User user = null; + if (uid != 0) { + user = MessagesController.getInstance(currentAccount).getUser(uid); + } if (user == null) { imagePressed = false; result = false; @@ -2673,7 +2677,11 @@ private void didClickedImage() { didPressButton(true, false); } } else if (currentMessageObject.type == 12) { - TLRPC.User user = MessagesController.getInstance(currentAccount).getUser(currentMessageObject.messageOwner.media.user_id); + long uid = currentMessageObject.messageOwner.media.user_id; + TLRPC.User user = null; + if (uid != 0) { + user = MessagesController.getInstance(currentAccount).getUser(uid); + } delegate.didPressUserAvatar(this, user, lastTouchX, lastTouchY); } else if (currentMessageObject.type == MessageObject.TYPE_ROUND_VIDEO) { if (buttonState != -1) { @@ -4419,7 +4427,10 @@ private void setMessageContent(MessageObject messageObject, MessageObject.Groupe availableTimeWidth = backgroundWidth - AndroidUtilities.dp(31); long uid = messageObject.messageOwner.media.user_id; - TLRPC.User user = MessagesController.getInstance(currentAccount).getUser(uid); + TLRPC.User user = null; + if (uid != 0) { + user = MessagesController.getInstance(currentAccount).getUser(uid); + } int maxWidth = getMaxNameWidth() - AndroidUtilities.dp(80); if (maxWidth < 0) { diff --git a/TMessagesProj/src/main/java/org/telegram/ui/Cells/SharedPhotoVideoCell2.java b/TMessagesProj/src/main/java/org/telegram/ui/Cells/SharedPhotoVideoCell2.java index fdf67d6b4e5..9fcf5fb1aea 100644 --- a/TMessagesProj/src/main/java/org/telegram/ui/Cells/SharedPhotoVideoCell2.java +++ b/TMessagesProj/src/main/java/org/telegram/ui/Cells/SharedPhotoVideoCell2.java @@ -24,6 +24,7 @@ import com.google.android.exoplayer2.util.Log; import org.telegram.messenger.AndroidUtilities; +import org.telegram.messenger.ApplicationLoader; import org.telegram.messenger.DownloadController; import org.telegram.messenger.FileLoader; import org.telegram.messenger.ImageLocation; @@ -166,7 +167,8 @@ public void setMessageObject(MessageObject messageObject, int parentColumnsCount if (messageObject.strippedThumb != null) { imageReceiver.setImage(null, null, null, null, messageObject.strippedThumb, 0, null, messageObject, 0); } else { - imageReceiver.clearImage(); + TLRPC.PhotoSize currentPhotoObjectThumb = FileLoader.getClosestPhotoSizeWithSize(messageObject.photoThumbs, 50); + imageReceiver.setImage(null, null, ImageLocation.getForObject(currentPhotoObjectThumb, messageObject.photoThumbsObject), "b", null, 0, null, messageObject, 0); } } } else { diff --git a/TMessagesProj/src/main/java/org/telegram/ui/ChannelAdminLogActivity.java b/TMessagesProj/src/main/java/org/telegram/ui/ChannelAdminLogActivity.java index 8624b3f7826..3d77cf3a42d 100644 --- a/TMessagesProj/src/main/java/org/telegram/ui/ChannelAdminLogActivity.java +++ b/TMessagesProj/src/main/java/org/telegram/ui/ChannelAdminLogActivity.java @@ -1215,7 +1215,11 @@ public void onAutoDeleteHistory(int ttl, int action) { } options.add(9); } else if (type == 8) { - TLRPC.User user = MessagesController.getInstance(currentAccount).getUser(selectedObject.messageOwner.media.user_id); + long uid = selectedObject.messageOwner.media.user_id; + TLRPC.User user = null; + if (uid != 0) { + user = MessagesController.getInstance(currentAccount).getUser(uid); + } if (user != null && user.id != UserConfig.getInstance(currentAccount).getClientUserId() && ContactsController.getInstance(currentAccount).contactsDict.get(user.id) == null) { items.add(LocaleController.getString("AddContactTitle", R.string.AddContactTitle)); options.add(15); diff --git a/TMessagesProj/src/main/java/org/telegram/ui/ChatActivity.java b/TMessagesProj/src/main/java/org/telegram/ui/ChatActivity.java index dec3ba22761..82c7b4d3d53 100644 --- a/TMessagesProj/src/main/java/org/telegram/ui/ChatActivity.java +++ b/TMessagesProj/src/main/java/org/telegram/ui/ChatActivity.java @@ -19797,7 +19797,11 @@ private void createMenu(View v, boolean single, boolean listView, float x, float } } } else if (type == 8) { - TLRPC.User user = getMessagesController().getUser(selectedObject.messageOwner.media.user_id); + long uid = selectedObject.messageOwner.media.user_id; + TLRPC.User user = null; + if (uid != 0) { + user = MessagesController.getInstance(currentAccount).getUser(uid); + } if (user != null && user.id != getUserConfig().getClientUserId() && getContactsController().contactsDict.get(user.id) == null) { items.add(LocaleController.getString("AddContactTitle", R.string.AddContactTitle)); options.add(15); @@ -19925,7 +19929,11 @@ private void createMenu(View v, boolean single, boolean listView, float x, float options.add(9); icons.add(R.drawable.msg_sticker); } else if (type == 8) { - TLRPC.User user = getMessagesController().getUser(selectedObject.messageOwner.media.user_id); + long uid = selectedObject.messageOwner.media.user_id; + TLRPC.User user = null; + if (uid != 0) { + user = MessagesController.getInstance(currentAccount).getUser(uid); + } if (user != null && user.id != getUserConfig().getClientUserId() && getContactsController().contactsDict.get(user.id) == null) { items.add(LocaleController.getString("AddContactTitle", R.string.AddContactTitle)); options.add(15); @@ -23154,7 +23162,12 @@ public void didPressInstantButton(ChatMessageCell cell, int type) { ArticleViewer.getInstance().open(messageObject); } } else if (type == 5) { - openVCard(getMessagesController().getUser(messageObject.messageOwner.media.user_id), messageObject.messageOwner.media.vcard, messageObject.messageOwner.media.first_name, messageObject.messageOwner.media.last_name); + long uid = messageObject.messageOwner.media.user_id; + TLRPC.User user = null; + if (uid != 0) { + user = MessagesController.getInstance(currentAccount).getUser(uid); + } + openVCard(user, messageObject.messageOwner.media.vcard, messageObject.messageOwner.media.first_name, messageObject.messageOwner.media.last_name); } else { if (messageObject.isSponsored()) { Bundle args = new Bundle(); diff --git a/TMessagesProj/src/main/java/org/telegram/ui/Components/JoinGroupAlert.java b/TMessagesProj/src/main/java/org/telegram/ui/Components/JoinGroupAlert.java index f9ff8fd718e..3826156a0a6 100644 --- a/TMessagesProj/src/main/java/org/telegram/ui/Components/JoinGroupAlert.java +++ b/TMessagesProj/src/main/java/org/telegram/ui/Components/JoinGroupAlert.java @@ -173,7 +173,7 @@ public JoinGroupAlert(final Context context, TLRPC.ChatInvite invite, String gro layout.titleTextView.setText(LocaleController.getString("RequestToJoinSent", R.string.RequestToJoinSent)); String subTitle = isChannel ? LocaleController.getString("RequestToJoinChannelSentDescription", R.string.RequestToJoinChannelSentDescription) - : LocaleController.getString("RequestToJoinSentDescription", R.string.RequestToJoinGroupSentDescription); + : LocaleController.getString("RequestToJoinGroupSentDescription", R.string.RequestToJoinGroupSentDescription); layout.subtitleTextView.setText(subTitle); Bulletin.make(fragment, layout, Bulletin.DURATION_LONG).show(); }); diff --git a/TMessagesProj/src/main/java/org/telegram/ui/Components/Paint/RenderView.java b/TMessagesProj/src/main/java/org/telegram/ui/Components/Paint/RenderView.java index c842fd82565..8d387e5702e 100644 --- a/TMessagesProj/src/main/java/org/telegram/ui/Components/Paint/RenderView.java +++ b/TMessagesProj/src/main/java/org/telegram/ui/Components/Paint/RenderView.java @@ -9,6 +9,8 @@ import android.view.TextureView; import android.view.View; +import com.google.android.exoplayer2.util.Log; + import javax.microedition.khronos.egl.EGL10; import javax.microedition.khronos.egl.EGLConfig; import javax.microedition.khronos.egl.EGLContext; @@ -64,7 +66,6 @@ public void onSurfaceTextureAvailable(SurfaceTexture surface, int width, int hei if (surface == null || internal != null) { return; } - internal = new CanvasInternal(surface); internal.setBufferSize(width, height); updateTransform(); @@ -263,7 +264,7 @@ private class CanvasInternal extends DispatchQueue { private EGLContext eglContext; private EGLSurface eglSurface; private boolean initialized; - private boolean ready; + private volatile boolean ready; private int bufferWidth; private int bufferHeight; @@ -438,7 +439,7 @@ public void run() { } if (!ready) { - queue.postRunnable(() -> ready = true, 200); + ready = true; } } }; diff --git a/TMessagesProj/src/main/java/org/telegram/ui/ContactAddActivity.java b/TMessagesProj/src/main/java/org/telegram/ui/ContactAddActivity.java index 78a597e7d2d..efae3945c65 100644 --- a/TMessagesProj/src/main/java/org/telegram/ui/ContactAddActivity.java +++ b/TMessagesProj/src/main/java/org/telegram/ui/ContactAddActivity.java @@ -81,7 +81,10 @@ public boolean onFragmentCreate() { phone = getArguments().getString("phone"); addContact = getArguments().getBoolean("addContact", false); needAddException = MessagesController.getNotificationsSettings(currentAccount).getBoolean("dialog_bar_exception" + user_id, false); - TLRPC.User user = getMessagesController().getUser(user_id); + TLRPC.User user = null; + if (user_id != 0) { + user = getMessagesController().getUser(user_id); + } return user != null && super.onFragmentCreate(); } diff --git a/TMessagesProj/src/main/java/org/telegram/ui/LoginActivity.java b/TMessagesProj/src/main/java/org/telegram/ui/LoginActivity.java index 3035a0162eb..b0dba751b0b 100644 --- a/TMessagesProj/src/main/java/org/telegram/ui/LoginActivity.java +++ b/TMessagesProj/src/main/java/org/telegram/ui/LoginActivity.java @@ -1595,10 +1595,14 @@ public void onNextPressed() { boolean allowCall = true; boolean allowCancelCall = true; boolean allowReadCallLog = true; + boolean allowReadPhoneNumbers = true; if (Build.VERSION.SDK_INT >= 23 && simcardAvailable) { allowCall = getParentActivity().checkSelfPermission(Manifest.permission.READ_PHONE_STATE) == PackageManager.PERMISSION_GRANTED; allowCancelCall = getParentActivity().checkSelfPermission(Manifest.permission.CALL_PHONE) == PackageManager.PERMISSION_GRANTED; allowReadCallLog = Build.VERSION.SDK_INT < 28 || getParentActivity().checkSelfPermission(Manifest.permission.READ_CALL_LOG) == PackageManager.PERMISSION_GRANTED; + if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) { + allowReadPhoneNumbers = getParentActivity().checkSelfPermission(Manifest.permission.READ_PHONE_NUMBERS) == PackageManager.PERMISSION_GRANTED; + } if (checkPermissions) { permissionsItems.clear(); if (!allowCall) { @@ -1610,6 +1614,9 @@ public void onNextPressed() { if (!allowReadCallLog) { permissionsItems.add(Manifest.permission.READ_CALL_LOG); } + if (!allowReadPhoneNumbers) { + permissionsItems.add(Manifest.permission.READ_PHONE_NUMBERS); + } boolean ok = true; if (!permissionsItems.isEmpty()) { SharedPreferences preferences = MessagesController.getGlobalMainSettings();