mirror of
				https://github.com/fabianonline/telegram_backup.git
				synced 2025-10-25 13:10:04 +00:00 
			
		
		
		
	You could call this version a first beta version.
This commit is contained in:
		
							
								
								
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -4,3 +4,4 @@ build/ | ||||
| auth.dat | ||||
| dc.dat | ||||
| data/ | ||||
| .DS_Store | ||||
|   | ||||
| @@ -9,6 +9,7 @@ import de.fabianonline.telegram_backup.Config; | ||||
| import de.fabianonline.telegram_backup.ApiStorage; | ||||
| import de.fabianonline.telegram_backup.UserManager; | ||||
| import de.fabianonline.telegram_backup.DownloadManager; | ||||
| import de.fabianonline.telegram_backup.CommandLineDownloadProgress; | ||||
|  | ||||
| import java.io.File; | ||||
| import java.io.IOException; | ||||
| @@ -61,12 +62,13 @@ public class CommandLineController { | ||||
| 				} | ||||
| 				storage.setPrefix("+" + user.getUser().getPhone()); | ||||
| 				 | ||||
| 				System.out.println("Next time, please run this tool with '--account " + user.getUser().getPhone() + " to use this account."); | ||||
| 				System.out.println("Please run this tool with '--account +" + user.getUser().getPhone() + " to use this account."); | ||||
| 				System.exit(0); | ||||
| 			} | ||||
| 			 | ||||
| 			System.out.println("You are logged in as " + user.getUserString()); | ||||
| 			 | ||||
| 			DownloadManager d = new DownloadManager(user, client); | ||||
| 			DownloadManager d = new DownloadManager(user, client, new CommandLineDownloadProgress()); | ||||
| 			d.downloadMessages(options.limit_messages); | ||||
| 			d.downloadMedia(); | ||||
| 		} catch (RpcErrorException e) { | ||||
|   | ||||
| @@ -0,0 +1,25 @@ | ||||
| package de.fabianonline.telegram_backup; | ||||
|  | ||||
| import de.fabianonline.telegram_backup.DownloadProgressInterface; | ||||
|  | ||||
| class CommandLineDownloadProgress implements DownloadProgressInterface { | ||||
| 	private int mediaCount = 0; | ||||
| 	private int i = 0; | ||||
| 	 | ||||
| 	public void onMessageDownloadStart(int count) { System.out.println("Downloading " + count + " messages."); } | ||||
| 	public void onMessageDownloaded(int number) { System.out.print("" + number + "..."); } | ||||
| 	public void onMessageDownloadFinished() { System.out.println(" done."); } | ||||
| 	 | ||||
| 	public void onMediaDownloadStart(int count) { i = 0; mediaCount = count; System.out.println("Checking " + count + " media."); } | ||||
| 	 | ||||
| 	public void onMediaDownloadedVideo(boolean n) { show(n, 'V'); } | ||||
| 	public void onMediaDownloadedPhoto(boolean n) { show(n, 'P'); } | ||||
| 	public void onMediaDownloadedDocument(boolean n) { show(n, 'D'); } | ||||
| 	public void onMediaDownloadedSticker(boolean n) { show(n, 'S'); } | ||||
| 	public void onMediaDownloadedOther(boolean n) { show(n, ' '); } | ||||
| 	public void onMediaDownloadFinished() { showNewLine(); System.out.println("Done."); } | ||||
| 	 | ||||
| 	private void show(boolean n, char letter) { System.out.print(n ? letter : '.'); i++; if (i % 50 == 0) showNewLine();} | ||||
| 	private void showNewLine() { System.out.println(" - " + i + "/" + mediaCount); } | ||||
| } | ||||
| 	 | ||||
| @@ -17,8 +17,8 @@ class Config { | ||||
|     public static final String FILE_FILES_BASE = "files"; | ||||
|     public static final String FILE_STICKER_BASE = "stickers"; | ||||
|      | ||||
|     public static final int FILE_DOWNLOAD_BLOCK_SIZE = 1024*1024; | ||||
|     public static final int FILE_DOWNLOAD_BLOCK_SIZE = 10*1024*1024; | ||||
|      | ||||
|     public static final int DELAY_AFTER_GET_FILE = 750; | ||||
|     public static final int DELAY_AFTER_GET_FILE = 200; | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -142,7 +142,6 @@ class Database { | ||||
| 						} else if (msg.getMedia() instanceof TLMessageMediaPhoto) { | ||||
| 							text = ((TLMessageMediaPhoto)msg.getMedia()).getCaption(); | ||||
| 						} | ||||
| 						System.out.println("" + msg.getId() + ": >" + text + "<"); | ||||
| 					} | ||||
| 					ps.setString(5, text); | ||||
| 					ps.setString(6, ""+msg.getDate()); | ||||
| @@ -163,7 +162,6 @@ class Database { | ||||
| 						} | ||||
| 					} | ||||
| 					if (sticker != null) { | ||||
| 						System.out.println("" + msg.getId() + ": >" + msg.getMessage() + "< " + sticker); | ||||
| 						ps.setString(9, sticker); | ||||
| 					} else { | ||||
| 						ps.setNull(9, Types.VARCHAR); | ||||
|   | ||||
| @@ -3,6 +3,7 @@ package de.fabianonline.telegram_backup; | ||||
| import de.fabianonline.telegram_backup.UserManager; | ||||
| import de.fabianonline.telegram_backup.Database; | ||||
| import de.fabianonline.telegram_backup.StickerConverter; | ||||
| import de.fabianonline.telegram_backup.DownloadProgressInterface; | ||||
|  | ||||
| import com.github.badoualy.telegram.api.TelegramClient; | ||||
| import com.github.badoualy.telegram.tl.core.TLIntVector; | ||||
| @@ -23,10 +24,12 @@ class DownloadManager { | ||||
| 	UserManager user; | ||||
| 	TelegramClient client; | ||||
| 	Database db; | ||||
| 	DownloadProgressInterface prog = null; | ||||
| 	 | ||||
| 	public DownloadManager(UserManager u, TelegramClient c) { | ||||
| 	public DownloadManager(UserManager u, TelegramClient c, DownloadProgressInterface p) { | ||||
| 		this.user = u; | ||||
| 		this.client = c; | ||||
| 		this.prog = p; | ||||
| 		this.db = new Database(u); | ||||
| 	} | ||||
| 	 | ||||
| @@ -60,25 +63,30 @@ class DownloadManager { | ||||
| 			return; | ||||
| 		} | ||||
| 		 | ||||
| 		prog.onMessageDownloadStart(end_id - current_start_id + 1); | ||||
| 		 | ||||
| 		while (current_start_id <= end_id) { | ||||
| 			int my_end_id = Math.min(current_start_id+99, end_id); | ||||
| 			ArrayList<Integer> a = makeIdList(current_start_id, my_end_id); | ||||
| 			TLIntVector ids = new TLIntVector(); | ||||
| 			ids.addAll(a); | ||||
| 			my_end_id = ids.get(ids.size()-1); | ||||
| 			System.out.println("Fetching messages from " + ids.get(0) + " to " + my_end_id + "..."); | ||||
| 			current_start_id = my_end_id + 1; | ||||
| 			 | ||||
| 			TLAbsMessages response = client.messagesGetMessages(ids); | ||||
| 			prog.onMessageDownloaded(response.getMessages().size()); | ||||
| 			db.save(response.getMessages()); | ||||
| 			try { | ||||
| 				Thread.sleep(750); | ||||
| 			} catch (InterruptedException e) {} | ||||
| 		} | ||||
| 		 | ||||
| 		prog.onMessageDownloadFinished(); | ||||
| 	} | ||||
| 	 | ||||
| 	public void downloadMedia() throws RpcErrorException, IOException { | ||||
| 		LinkedList<TLMessage> messages = this.db.getMessagesWithMedia(); | ||||
| 		prog.onMediaDownloadStart(messages.size()); | ||||
| 		for (TLMessage msg : messages) { | ||||
| 			TLAbsMessageMedia media = msg.getMedia(); | ||||
| 			 | ||||
| @@ -88,22 +96,19 @@ class DownloadManager { | ||||
| 				this.downloadMessageMediaDocument(msg, (TLMessageMediaDocument)media); | ||||
| 			} else if (media instanceof TLMessageMediaVideo) { | ||||
| 				this.downloadMessageMediaVideo(msg, (TLMessageMediaVideo)media); | ||||
| 			} else if (media instanceof TLMessageMediaEmpty) { | ||||
| 				// do nothing | ||||
| 			} else if (media instanceof TLMessageMediaUnsupported) { | ||||
| 				// do nothing | ||||
| 			} else if (media instanceof TLMessageMediaGeo) { | ||||
| 				// do nothing | ||||
| 			} else if (media instanceof TLMessageMediaWebPage) { | ||||
| 				// do nothing | ||||
| 			} else if (media instanceof TLMessageMediaContact) { | ||||
| 				// do nothing | ||||
| 			} else if (media instanceof TLMessageMediaVenue) { | ||||
| 			} else if (media instanceof TLMessageMediaEmpty || | ||||
| 				media instanceof TLMessageMediaUnsupported || | ||||
| 				media instanceof TLMessageMediaGeo || | ||||
| 				media instanceof TLMessageMediaWebPage || | ||||
| 				media instanceof TLMessageMediaContact || | ||||
| 				media instanceof TLMessageMediaVenue) { | ||||
| 				prog.onMediaDownloadedOther(true); | ||||
| 				// do nothing | ||||
| 			} else { | ||||
| 				throw new RuntimeException("Unexpected " + media.getClass().getName()); | ||||
| 			} | ||||
| 		} | ||||
| 		prog.onMediaDownloadFinished(); | ||||
| 	} | ||||
| 	 | ||||
| 	private void downloadMessageMediaPhoto(TLMessage msg, TLMessageMediaPhoto p) throws RpcErrorException, IOException { | ||||
| @@ -122,7 +127,8 @@ class DownloadManager { | ||||
| 				throw new RuntimeException("Could not find a size for a photo."); | ||||
| 			} | ||||
| 			if (size.getLocation() instanceof TLFileLocation) { | ||||
| 				this.downloadPhoto(msg.getId(), (TLFileLocation)size.getLocation()); | ||||
| 				boolean res = this.downloadPhoto(msg.getId(), (TLFileLocation)size.getLocation()); | ||||
| 				prog.onMediaDownloadedPhoto(res); | ||||
| 			} | ||||
| 		} else { | ||||
| 			throw new RuntimeException("Got an unexpected " + p.getPhoto().getClass().getName()); | ||||
| @@ -164,7 +170,12 @@ class DownloadManager { | ||||
| 				filename = this.makeFilename(msg.getId(), ext); | ||||
| 			} | ||||
| 			 | ||||
| 			this.downloadDocument(filename, doc); | ||||
| 			boolean res = this.downloadDocument(filename, doc); | ||||
| 			if (sticker != null) { | ||||
| 				prog.onMediaDownloadedSticker(res); | ||||
| 			} else { | ||||
| 				prog.onMediaDownloadedDocument(res); | ||||
| 			} | ||||
| 		} else { | ||||
| 			throw new RuntimeException("Got an unexpected " + d.getDocument().getClass().getName()); | ||||
| 		} | ||||
| @@ -175,7 +186,8 @@ class DownloadManager { | ||||
| 			TLVideo vid = (TLVideo)v.getVideo(); | ||||
| 			int i = vid.getMimeType().lastIndexOf('/'); | ||||
| 			String ext = vid.getMimeType().substring(i+1).toLowerCase(); | ||||
| 			this.downloadVideo(this.makeFilename(msg.getId(), ext), vid); | ||||
| 			boolean res = this.downloadVideo(this.makeFilename(msg.getId(), ext), vid); | ||||
| 			prog.onMediaDownloadedVideo(res); | ||||
| 		} | ||||
| 	} | ||||
| 	 | ||||
| @@ -186,27 +198,27 @@ class DownloadManager { | ||||
| 		return a;  | ||||
| 	} | ||||
| 	 | ||||
| 	private void downloadPhoto(int msgId, TLFileLocation src) throws RpcErrorException, IOException { | ||||
| 	private boolean downloadPhoto(int msgId, TLFileLocation src) throws RpcErrorException, IOException { | ||||
| 		TLInputFileLocation loc = new TLInputFileLocation(); | ||||
| 		loc.setVolumeId(src.getVolumeId()); | ||||
| 		loc.setLocalId(src.getLocalId()); | ||||
| 		loc.setSecret(src.getSecret()); | ||||
| 		 | ||||
| 		this.downloadFile(this.makeFilename(msgId, "jpg"), loc); | ||||
| 		return this.downloadFile(this.makeFilename(msgId, "jpg"), loc); | ||||
| 	} | ||||
| 	 | ||||
| 	private void downloadDocument(String filename, TLDocument doc) throws RpcErrorException, IOException { | ||||
| 	private boolean downloadDocument(String filename, TLDocument doc) throws RpcErrorException, IOException { | ||||
| 		TLInputDocumentFileLocation loc = new TLInputDocumentFileLocation(); | ||||
| 		loc.setId(doc.getId()); | ||||
| 		loc.setAccessHash(doc.getAccessHash()); | ||||
| 		this.downloadFileFromDc(filename, loc, doc.getDcId()); | ||||
| 		return this.downloadFileFromDc(filename, loc, doc.getDcId()); | ||||
| 	} | ||||
| 	 | ||||
| 	private void downloadVideo(String filename, TLVideo vid) throws RpcErrorException, IOException { | ||||
| 	private boolean downloadVideo(String filename, TLVideo vid) throws RpcErrorException, IOException { | ||||
| 		TLInputDocumentFileLocation loc = new TLInputDocumentFileLocation(); | ||||
| 		loc.setId(vid.getId()); | ||||
| 		loc.setAccessHash(vid.getAccessHash()); | ||||
| 		this.downloadFileFromDc(filename, loc, vid.getDcId()); | ||||
| 		return this.downloadFileFromDc(filename, loc, vid.getDcId()); | ||||
| 	} | ||||
| 	 | ||||
| 	private String makeFilename(int id, String ext) { | ||||
| @@ -218,13 +230,13 @@ class DownloadManager { | ||||
| 		return path + id + ".dat"; | ||||
| 	} | ||||
| 	 | ||||
| 	private void downloadFile(String target, TLAbsInputFileLocation loc) throws RpcErrorException, IOException { | ||||
| 		downloadFileFromDc(target, loc, null); | ||||
| 	private boolean downloadFile(String target, TLAbsInputFileLocation loc) throws RpcErrorException, IOException { | ||||
| 		return downloadFileFromDc(target, loc, null); | ||||
| 	} | ||||
| 	 | ||||
| 	private void downloadFileFromDc(String target, TLAbsInputFileLocation loc, Integer dcID) throws RpcErrorException, IOException { | ||||
| 	private boolean downloadFileFromDc(String target, TLAbsInputFileLocation loc, Integer dcID) throws RpcErrorException, IOException { | ||||
| 		// Don't download already existing files. | ||||
| 		if (new File(target).isFile()) return; | ||||
| 		if (new File(target).isFile()) return false; | ||||
| 		 | ||||
| 		FileOutputStream fos = null; | ||||
| 		try { | ||||
| @@ -243,6 +255,7 @@ class DownloadManager { | ||||
| 				try { Thread.sleep(Config.DELAY_AFTER_GET_FILE); } catch(InterruptedException e) {} | ||||
| 			} while(response.getBytes().getLength() == Config.FILE_DOWNLOAD_BLOCK_SIZE); | ||||
| 			fos.close(); | ||||
| 			return true; | ||||
| 		} catch (java.io.IOException ex) { | ||||
| 			if (fos!=null) fos.close(); | ||||
| 			new File(target).delete(); | ||||
|   | ||||
| @@ -0,0 +1,15 @@ | ||||
| package de.fabianonline.telegram_backup; | ||||
|  | ||||
| interface DownloadProgressInterface { | ||||
| 	public void onMessageDownloadStart(int count); | ||||
| 	public void onMessageDownloaded(int number); | ||||
| 	public void onMessageDownloadFinished(); | ||||
| 	 | ||||
| 	public void onMediaDownloadStart(int count); | ||||
| 	public void onMediaDownloadedVideo(boolean n); | ||||
| 	public void onMediaDownloadedPhoto(boolean n); | ||||
| 	public void onMediaDownloadedDocument(boolean n); | ||||
| 	public void onMediaDownloadedSticker(boolean n); | ||||
| 	public void onMediaDownloadedOther(boolean n); | ||||
| 	public void onMediaDownloadFinished(); | ||||
| } | ||||
		Reference in New Issue
	
	Block a user