mirror of
https://github.com/fabianonline/telegram_backup.git
synced 2024-11-22 16:56:16 +00:00
Beginnings of a Swing GUI.
This commit is contained in:
parent
c0bc3cdd2d
commit
ba7e76087a
@ -5,24 +5,18 @@ import com.github.badoualy.telegram.api.TelegramApp;
|
|||||||
import com.github.badoualy.telegram.api.TelegramClient;
|
import com.github.badoualy.telegram.api.TelegramClient;
|
||||||
import com.github.badoualy.telegram.tl.exception.RpcErrorException;
|
import com.github.badoualy.telegram.tl.exception.RpcErrorException;
|
||||||
|
|
||||||
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.File;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
import java.util.List;
|
||||||
import java.util.Scanner;
|
import java.util.Scanner;
|
||||||
|
|
||||||
public class CommandLineController {
|
public class CommandLineController {
|
||||||
private ApiStorage storage;
|
private ApiStorage storage;
|
||||||
private CommandLineOptions options;
|
|
||||||
public TelegramApp app;
|
public TelegramApp app;
|
||||||
public UserManager user = null;
|
public UserManager user = null;
|
||||||
|
|
||||||
public CommandLineController(String[] args) {
|
public CommandLineController(CommandLineOptions options) {
|
||||||
options = new CommandLineOptions(args);
|
|
||||||
if (options.cmd_help) this.show_help();
|
if (options.cmd_help) this.show_help();
|
||||||
if (options.cmd_list_accounts) this.list_accounts();
|
if (options.cmd_list_accounts) this.list_accounts();
|
||||||
if (options.account==null && !options.cmd_login) {
|
if (options.account==null && !options.cmd_login) {
|
||||||
@ -95,17 +89,12 @@ public class CommandLineController {
|
|||||||
|
|
||||||
private void list_accounts() {
|
private void list_accounts() {
|
||||||
System.out.println("List of available accounts:");
|
System.out.println("List of available accounts:");
|
||||||
int count = 0;
|
List<String> accounts = Utils.getAccounts();
|
||||||
File folder = new File(Config.FILE_BASE);
|
if (accounts.size()>0) {
|
||||||
File[] files = folder.listFiles();
|
for (String str : accounts) {
|
||||||
for (File f : files) {
|
System.out.println(" " + str);
|
||||||
if (f.isDirectory()) {
|
|
||||||
count++;
|
|
||||||
System.out.println(" " + f.getName());
|
|
||||||
}
|
}
|
||||||
}
|
System.out.println("Use '--account <x>' to use one of those accounts.");
|
||||||
if (count>0) {
|
|
||||||
System.out.println("Use '--acount <x>' to use one of those accounts.");
|
|
||||||
} else {
|
} else {
|
||||||
System.out.println("NO ACCOUNTS FOUND");
|
System.out.println("NO ACCOUNTS FOUND");
|
||||||
System.out.println("Use '--login' to login to a telegram account.");
|
System.out.println("Use '--login' to login to a telegram account.");
|
||||||
@ -118,40 +107,4 @@ public class CommandLineController {
|
|||||||
System.exit(1);
|
System.exit(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
private class CommandLineOptions {
|
|
||||||
public String account = null;
|
|
||||||
public boolean cmd_help = false;
|
|
||||||
public boolean cmd_login = false;
|
|
||||||
public boolean cmd_debug = false;
|
|
||||||
public boolean cmd_list_accounts = false;
|
|
||||||
public Integer limit_messages = null;
|
|
||||||
|
|
||||||
public CommandLineOptions(String[] args) {
|
|
||||||
String last_cmd = null;
|
|
||||||
|
|
||||||
for (String arg : args) {
|
|
||||||
if (last_cmd != null) {
|
|
||||||
switch(last_cmd) {
|
|
||||||
case "--account": this.account=arg; break;
|
|
||||||
case "--limit-messages": this.limit_messages=Integer.parseInt(arg); break;
|
|
||||||
}
|
|
||||||
last_cmd = null;
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
switch(arg) {
|
|
||||||
case "--account": last_cmd=arg; continue;
|
|
||||||
case "--help": this.cmd_help=true; break;
|
|
||||||
case "--login": this.cmd_login=true; break;
|
|
||||||
case "--debug": this.cmd_debug=true; break;
|
|
||||||
case "--list-accounts": this.cmd_list_accounts=true; break;
|
|
||||||
case "--limit-messages": last_cmd=arg; continue;
|
|
||||||
default: throw new RuntimeException("Unknown command " + arg);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (last_cmd != null) {
|
|
||||||
CommandLineController.show_error("Command " + last_cmd + " had no parameter set.");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@ -0,0 +1,59 @@
|
|||||||
|
package de.fabianonline.telegram_backup;
|
||||||
|
|
||||||
|
class CommandLineOptions {
|
||||||
|
public boolean cmd_console = false;
|
||||||
|
public String account = null;
|
||||||
|
public boolean cmd_help = false;
|
||||||
|
public boolean cmd_login = false;
|
||||||
|
public boolean cmd_debug = false;
|
||||||
|
public boolean cmd_list_accounts = false;
|
||||||
|
public Integer limit_messages = null;
|
||||||
|
|
||||||
|
public CommandLineOptions(String[] args) {
|
||||||
|
String last_cmd = null;
|
||||||
|
|
||||||
|
for (String arg : args) {
|
||||||
|
if (last_cmd != null) {
|
||||||
|
switch (last_cmd) {
|
||||||
|
case "--account":
|
||||||
|
this.account = arg;
|
||||||
|
break;
|
||||||
|
case "--limit-messages":
|
||||||
|
this.limit_messages = Integer.parseInt(arg);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
last_cmd = null;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
switch (arg) {
|
||||||
|
case "--account":
|
||||||
|
last_cmd = arg;
|
||||||
|
continue;
|
||||||
|
case "--help":
|
||||||
|
this.cmd_help = true;
|
||||||
|
break;
|
||||||
|
case "--login":
|
||||||
|
this.cmd_login = true;
|
||||||
|
break;
|
||||||
|
case "--debug":
|
||||||
|
this.cmd_debug = true;
|
||||||
|
break;
|
||||||
|
case "--list-accounts":
|
||||||
|
this.cmd_list_accounts = true;
|
||||||
|
break;
|
||||||
|
case "--limit-messages":
|
||||||
|
last_cmd = arg;
|
||||||
|
continue;
|
||||||
|
case "--console":
|
||||||
|
this.cmd_console = true;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
throw new RuntimeException("Unknown command " + arg);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (last_cmd != null) {
|
||||||
|
CommandLineController.show_error("Command " + last_cmd + " had no parameter set.");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -4,6 +4,12 @@ import de.fabianonline.telegram_backup.CommandLineController;
|
|||||||
|
|
||||||
public class CommandLineRunner {
|
public class CommandLineRunner {
|
||||||
public static void main(String[] args) {
|
public static void main(String[] args) {
|
||||||
new CommandLineController(args);
|
CommandLineOptions options = new CommandLineOptions(args);
|
||||||
|
if (true || options.cmd_console) {
|
||||||
|
// Always use the console for now.
|
||||||
|
new CommandLineController(options);
|
||||||
|
} else {
|
||||||
|
new GUIController(options);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -0,0 +1,88 @@
|
|||||||
|
package de.fabianonline.telegram_backup;
|
||||||
|
|
||||||
|
import javax.swing.*;
|
||||||
|
import javax.swing.event.ListSelectionEvent;
|
||||||
|
import javax.swing.event.ListSelectionListener;
|
||||||
|
import java.awt.*;
|
||||||
|
import java.awt.event.ActionEvent;
|
||||||
|
import java.awt.event.ActionListener;
|
||||||
|
import java.util.Vector;
|
||||||
|
|
||||||
|
public class GUIController {
|
||||||
|
private CommandLineOptions options;
|
||||||
|
|
||||||
|
public GUIController(CommandLineOptions options) {
|
||||||
|
this.options = options;
|
||||||
|
showAccountChooserDialog();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void showAccountChooserDialog() {
|
||||||
|
JDialog accountChooser = new JDialog();
|
||||||
|
accountChooser.setTitle("Choose account");
|
||||||
|
accountChooser.setSize(400, 200);
|
||||||
|
JPanel vert = new JPanel();
|
||||||
|
vert.setLayout(new BorderLayout());
|
||||||
|
vert.add(new JLabel("Please select the account to use or create a new one."), BorderLayout.NORTH);
|
||||||
|
Vector<String> accounts = Utils.getAccounts();
|
||||||
|
JList<String> list = new JList<String>(accounts);
|
||||||
|
list.setSelectionMode(ListSelectionModel.SINGLE_SELECTION);
|
||||||
|
vert.add(list, BorderLayout.CENTER);
|
||||||
|
JPanel bottom = new JPanel(new GridLayout(1, 2));
|
||||||
|
JButton btnAddAccount = new JButton("Add account");
|
||||||
|
bottom.add(btnAddAccount);
|
||||||
|
JButton btnLogin = new JButton("Login");
|
||||||
|
btnLogin.setEnabled(false);
|
||||||
|
bottom.add(btnLogin);
|
||||||
|
vert.add(bottom, BorderLayout.SOUTH);
|
||||||
|
accountChooser.add(vert);
|
||||||
|
accountChooser.setVisible(true);
|
||||||
|
accountChooser.setDefaultCloseOperation(JDialog.DISPOSE_ON_CLOSE);
|
||||||
|
|
||||||
|
list.addListSelectionListener(new ListSelectionListener() {
|
||||||
|
@Override
|
||||||
|
public void valueChanged(ListSelectionEvent e) {
|
||||||
|
btnLogin.setEnabled(true);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
btnAddAccount.addActionListener(new ActionListener() {
|
||||||
|
@Override
|
||||||
|
public void actionPerformed(ActionEvent e) {
|
||||||
|
accountChooser.setVisible(false);
|
||||||
|
accountChooser.dispose();
|
||||||
|
addAccountDialog();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
private void addAccountDialog() {
|
||||||
|
JDialog loginDialog = new JDialog();
|
||||||
|
loginDialog.setTitle("Add an account");
|
||||||
|
loginDialog.setDefaultCloseOperation(JDialog.DISPOSE_ON_CLOSE);
|
||||||
|
|
||||||
|
JPanel sections = new JPanel();
|
||||||
|
sections.setLayout(new BoxLayout(sections, BoxLayout.Y_AXIS));
|
||||||
|
|
||||||
|
JPanel top = new JPanel();
|
||||||
|
top.setLayout(new BoxLayout(top, BoxLayout.Y_AXIS));
|
||||||
|
top.add(new JLabel("Please enter your phone number in international format:"));
|
||||||
|
top.add(new JTextField("+49123773212"));
|
||||||
|
|
||||||
|
sections.add(top);
|
||||||
|
sections.add(Box.createVerticalStrut(5));
|
||||||
|
sections.add(new JSeparator(SwingConstants.HORIZONTAL));
|
||||||
|
|
||||||
|
JPanel middle = new JPanel();
|
||||||
|
middle.setLayout(new BoxLayout(middle, BoxLayout.Y_AXIS));
|
||||||
|
middle.add(new JLabel("Telegram sent you a code. Enter it here:"));
|
||||||
|
middle.add(new JTextField());
|
||||||
|
middle.setEnabled(false);
|
||||||
|
|
||||||
|
sections.add(middle);
|
||||||
|
sections.add(Box.createVerticalStrut(5));
|
||||||
|
sections.add(new JSeparator(SwingConstants.HORIZONTAL));
|
||||||
|
|
||||||
|
loginDialog.add(sections);
|
||||||
|
loginDialog.setVisible(true);
|
||||||
|
}
|
||||||
|
}
|
19
src/main/java/de/fabianonline/telegram_backup/Utils.java
Normal file
19
src/main/java/de/fabianonline/telegram_backup/Utils.java
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
package de.fabianonline.telegram_backup;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Vector;
|
||||||
|
|
||||||
|
public class Utils {
|
||||||
|
static Vector<String> getAccounts() {
|
||||||
|
Vector<String> accounts = new Vector<String>();
|
||||||
|
File folder = new File(Config.FILE_BASE);
|
||||||
|
File[] files = folder.listFiles();
|
||||||
|
for (File f : files) {
|
||||||
|
if (f.isDirectory() && f.getName().startsWith("+")) {
|
||||||
|
accounts.add(f.getName());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return accounts;
|
||||||
|
}
|
||||||
|
}
|
11
src/main/main.iml
Normal file
11
src/main/main.iml
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<module type="JAVA_MODULE" version="4">
|
||||||
|
<component name="NewModuleRootManager" inherit-compiler-output="true">
|
||||||
|
<exclude-output />
|
||||||
|
<content url="file://$MODULE_DIR$">
|
||||||
|
<sourceFolder url="file://$MODULE_DIR$/java" isTestSource="false" />
|
||||||
|
</content>
|
||||||
|
<orderEntry type="inheritedJdk" />
|
||||||
|
<orderEntry type="sourceFolder" forTests="false" />
|
||||||
|
</component>
|
||||||
|
</module>
|
Loading…
Reference in New Issue
Block a user