added authing from ui
This commit is contained in:
parent
23d2b1cffa
commit
d035193976
@ -20,6 +20,7 @@ import com.mashape.unirest.request.HttpRequestWithBody;
|
|||||||
|
|
||||||
import sarsoo.fmframework.log.Logger;
|
import sarsoo.fmframework.log.Logger;
|
||||||
import sarsoo.fmframework.log.entry.ErrorEntry;
|
import sarsoo.fmframework.log.entry.ErrorEntry;
|
||||||
|
import sarsoo.fmframework.log.entry.LogEntry;
|
||||||
import sarsoo.fmframework.music.Scrobble;
|
import sarsoo.fmframework.music.Scrobble;
|
||||||
|
|
||||||
public class FmAuthNetwork extends FmUserNetwork {
|
public class FmAuthNetwork extends FmUserNetwork {
|
||||||
@ -33,6 +34,8 @@ public class FmAuthNetwork extends FmUserNetwork {
|
|||||||
|
|
||||||
public void scrobble(Scrobble scrobble, String sk) {
|
public void scrobble(Scrobble scrobble, String sk) {
|
||||||
|
|
||||||
|
Logger.getLog().log(new LogEntry("scrobble").addArg(scrobble.toString()));
|
||||||
|
|
||||||
HashMap<String, String> params = new HashMap<String, String>();
|
HashMap<String, String> params = new HashMap<String, String>();
|
||||||
|
|
||||||
params.put("artist", scrobble.getTrack().getArtist().getName());
|
params.put("artist", scrobble.getTrack().getArtist().getName());
|
||||||
@ -47,17 +50,20 @@ public class FmAuthNetwork extends FmUserNetwork {
|
|||||||
|
|
||||||
JSONObject obj = makeAuthPostRequest("track.scrobble", params);
|
JSONObject obj = makeAuthPostRequest("track.scrobble", params);
|
||||||
|
|
||||||
System.out.println(obj.toString());
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public String getToken() {
|
public String getToken() {
|
||||||
|
|
||||||
|
Logger.getLog().log(new LogEntry("getToken"));
|
||||||
|
|
||||||
JSONObject obj = makeAuthGetRequest("auth.gettoken");
|
JSONObject obj = makeAuthGetRequest("auth.gettoken");
|
||||||
|
|
||||||
return obj.getString("token");
|
return obj.getString("token");
|
||||||
}
|
}
|
||||||
|
|
||||||
public String getSession(String token) {
|
public String getSession(String token) {
|
||||||
|
|
||||||
|
Logger.getLog().log(new LogEntry("getSession"));
|
||||||
|
|
||||||
HashMap<String, String> params = new HashMap<String, String>();
|
HashMap<String, String> params = new HashMap<String, String>();
|
||||||
params.put("token", token);
|
params.put("token", token);
|
||||||
|
@ -10,13 +10,17 @@ import java.util.Locale;
|
|||||||
import javax.swing.JOptionPane;
|
import javax.swing.JOptionPane;
|
||||||
|
|
||||||
import javafx.event.ActionEvent;
|
import javafx.event.ActionEvent;
|
||||||
|
import javafx.event.Event;
|
||||||
import javafx.event.EventHandler;
|
import javafx.event.EventHandler;
|
||||||
import javafx.fxml.FXML;
|
import javafx.fxml.FXML;
|
||||||
import javafx.stage.FileChooser;
|
import javafx.stage.FileChooser;
|
||||||
import sarsoo.fmframework.config.Config;
|
import sarsoo.fmframework.config.Config;
|
||||||
|
import sarsoo.fmframework.config.ConfigVariable;
|
||||||
import sarsoo.fmframework.config.VariableEvent;
|
import sarsoo.fmframework.config.VariableEvent;
|
||||||
import sarsoo.fmframework.config.VariableListener;
|
import sarsoo.fmframework.config.VariableListener;
|
||||||
import sarsoo.fmframework.file.ListPersister;
|
import sarsoo.fmframework.file.ListPersister;
|
||||||
|
import sarsoo.fmframework.fm.FmAuthNetwork;
|
||||||
|
import sarsoo.fmframework.fm.FmNetwork;
|
||||||
import sarsoo.fmframework.fx.TextAreaConsole;
|
import sarsoo.fmframework.fx.TextAreaConsole;
|
||||||
import sarsoo.fmframework.fx.service.GetLastTrackService;
|
import sarsoo.fmframework.fx.service.GetLastTrackService;
|
||||||
import sarsoo.fmframework.fx.service.GetScrobbleCountService;
|
import sarsoo.fmframework.fx.service.GetScrobbleCountService;
|
||||||
@ -30,6 +34,7 @@ import sarsoo.fmframework.fx.tab.FMObjListEditTab;
|
|||||||
import sarsoo.fmframework.fx.tab.GenrePieChartTab;
|
import sarsoo.fmframework.fx.tab.GenrePieChartTab;
|
||||||
import sarsoo.fmframework.fx.tab.ScrobbleChartTab;
|
import sarsoo.fmframework.fx.tab.ScrobbleChartTab;
|
||||||
import sarsoo.fmframework.fx.tab.TrackTab;
|
import sarsoo.fmframework.fx.tab.TrackTab;
|
||||||
|
import sarsoo.fmframework.fx.tab.WebViewTab;
|
||||||
import sarsoo.fmframework.log.Log;
|
import sarsoo.fmframework.log.Log;
|
||||||
import sarsoo.fmframework.log.Logger;
|
import sarsoo.fmframework.log.Logger;
|
||||||
import sarsoo.fmframework.fx.FmFramework;
|
import sarsoo.fmframework.fx.FmFramework;
|
||||||
@ -50,36 +55,36 @@ public class RootController {
|
|||||||
@FXML
|
@FXML
|
||||||
public void initialize() {
|
public void initialize() {
|
||||||
Logger.setLog(new Log(TextAreaConsole.getInstance(), false));
|
Logger.setLog(new Log(TextAreaConsole.getInstance(), false));
|
||||||
|
|
||||||
Config config = FmFramework.getSessionConfig();
|
Config config = FmFramework.getSessionConfig();
|
||||||
|
|
||||||
if(config.getVariable("api_key") == null) {
|
if (config.getVariable("api_key") == null) {
|
||||||
while(config.getVariable("api_key") == null) {
|
while (config.getVariable("api_key") == null) {
|
||||||
setApiKey();
|
setApiKey();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if(config.getVariable("username") == null) {
|
if (config.getVariable("username") == null) {
|
||||||
while(config.getVariable("username") == null) {
|
while (config.getVariable("username") == null) {
|
||||||
changeUsername();
|
changeUsername();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
FmFramework.getSessionConfig().getVariable("username").addListener(new VariableListener() {
|
FmFramework.getSessionConfig().getVariable("username").addListener(new VariableListener() {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void listen(VariableEvent event) {
|
public void listen(VariableEvent event) {
|
||||||
refresh();
|
refresh();
|
||||||
}
|
}
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|
||||||
refresh();
|
refresh();
|
||||||
}
|
}
|
||||||
|
|
||||||
public void refresh() {
|
public void refresh() {
|
||||||
labelStatsUsername.setText(FmFramework.getSessionConfig().getValue("username"));
|
labelStatsUsername.setText(FmFramework.getSessionConfig().getValue("username"));
|
||||||
|
|
||||||
refreshScrobbleCounts();
|
refreshScrobbleCounts();
|
||||||
addLastTrackTab();
|
addLastTrackTab();
|
||||||
refreshTagMenu();
|
refreshTagMenu();
|
||||||
@ -192,10 +197,54 @@ public class RootController {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@FXML
|
@FXML
|
||||||
protected void handleChangeUsername(ActionEvent event) throws IOException {
|
protected void handleChangeUsername(ActionEvent event) {
|
||||||
changeUsername();
|
changeUsername();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@FXML
|
||||||
|
protected void handleAuth(ActionEvent event) {
|
||||||
|
try {
|
||||||
|
|
||||||
|
Config config = FmFramework.getSessionConfig();
|
||||||
|
|
||||||
|
if (config.getVariable("api_secret") != null) {
|
||||||
|
|
||||||
|
FmAuthNetwork net = new FmAuthNetwork(config.getValue("api_key"), config.getValue("api_secret"),
|
||||||
|
config.getValue("username"));
|
||||||
|
|
||||||
|
String token = net.getToken();
|
||||||
|
|
||||||
|
String url = String.format("http://www.last.fm/api/auth/?api_key=%s&token=%s",
|
||||||
|
config.getValue("api_key"), token);
|
||||||
|
|
||||||
|
Tab tab = new WebViewTab(url);
|
||||||
|
|
||||||
|
tab.setOnClosed(new EventHandler<Event>() {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void handle(Event arg0) {
|
||||||
|
completeAuth(net, token);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
addTab(tab);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
} catch (IOException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void completeAuth(FmAuthNetwork net, String token) {
|
||||||
|
|
||||||
|
String sk = net.getSession(token);
|
||||||
|
|
||||||
|
if (sk != null) {
|
||||||
|
FmFramework.getSessionConfig().addVariable(new ConfigVariable("session_key", sk));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public void changeUsername() {
|
public void changeUsername() {
|
||||||
Service<Void> service = new Service<Void>() {
|
Service<Void> service = new Service<Void>() {
|
||||||
@Override
|
@Override
|
||||||
@ -216,7 +265,7 @@ public class RootController {
|
|||||||
};
|
};
|
||||||
service.start();
|
service.start();
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setApiKey() {
|
public void setApiKey() {
|
||||||
Service<Void> service = new Service<Void>() {
|
Service<Void> service = new Service<Void>() {
|
||||||
@Override
|
@Override
|
||||||
@ -356,7 +405,7 @@ public class RootController {
|
|||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@FXML
|
@FXML
|
||||||
protected void handlePrintConfig(ActionEvent event) {
|
protected void handlePrintConfig(ActionEvent event) {
|
||||||
System.out.println(FmFramework.getSessionConfig());
|
System.out.println(FmFramework.getSessionConfig());
|
||||||
|
28
src/main/java/sarsoo/fmframework/fx/tab/WebViewTab.java
Normal file
28
src/main/java/sarsoo/fmframework/fx/tab/WebViewTab.java
Normal file
@ -0,0 +1,28 @@
|
|||||||
|
package sarsoo.fmframework.fx.tab;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
|
||||||
|
import javafx.scene.control.*;
|
||||||
|
import javafx.scene.layout.*;
|
||||||
|
import javafx.scene.web.WebEngine;
|
||||||
|
import javafx.scene.web.WebView;
|
||||||
|
|
||||||
|
public class WebViewTab extends Tab {
|
||||||
|
|
||||||
|
public WebViewTab(String path) throws IOException {
|
||||||
|
|
||||||
|
setText("web view");
|
||||||
|
|
||||||
|
StackPane pane = new StackPane();
|
||||||
|
|
||||||
|
WebView web = new WebView();
|
||||||
|
|
||||||
|
pane.getChildren().add(web);
|
||||||
|
|
||||||
|
WebEngine webEngine = web.getEngine();
|
||||||
|
webEngine.load(path);
|
||||||
|
|
||||||
|
setContent(pane);
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
@ -34,6 +34,7 @@
|
|||||||
<Menu fx:id="menuUtil" mnemonicParsing="false" text="util">
|
<Menu fx:id="menuUtil" mnemonicParsing="false" text="util">
|
||||||
<items>
|
<items>
|
||||||
<MenuItem fx:id="menuItemScrobble" mnemonicParsing="false" onAction="#handleScrobble" text="scrobble" />
|
<MenuItem fx:id="menuItemScrobble" mnemonicParsing="false" onAction="#handleScrobble" text="scrobble" />
|
||||||
|
<MenuItem fx:id="menuItemAuth" mnemonicParsing="false" onAction="#handleAuth" text="authenticate" />
|
||||||
<MenuItem fx:id="menuItemOpenConsole" mnemonicParsing="false" onAction="#handleOpenConsole" text="open console" />
|
<MenuItem fx:id="menuItemOpenConsole" mnemonicParsing="false" onAction="#handleOpenConsole" text="open console" />
|
||||||
<MenuItem mnemonicParsing="false" onAction="#handleChangeUsername" text="set username" />
|
<MenuItem mnemonicParsing="false" onAction="#handleChangeUsername" text="set username" />
|
||||||
<MenuItem fx:id="menuItemPrintConfig" mnemonicParsing="false" onAction="#handlePrintConfig" text="print config" />
|
<MenuItem fx:id="menuItemPrintConfig" mnemonicParsing="false" onAction="#handlePrintConfig" text="print config" />
|
||||||
|
@ -17,29 +17,29 @@ public class FmAuthNetworkTest {
|
|||||||
@Test
|
@Test
|
||||||
public void test() {
|
public void test() {
|
||||||
|
|
||||||
FmAuthNetwork net = new FmAuthNetwork(Key.getKey(), Key.getSecret(), "sarsoo");
|
// FmAuthNetwork net = new FmAuthNetwork(Key.getKey(), Key.getSecret(), "sarsoo");
|
||||||
|
|
||||||
// HashMap<String, String> hash = new HashMap<>();
|
|
||||||
//
|
//
|
||||||
// hash.put("zoo", "ash");
|
//// HashMap<String, String> hash = new HashMap<>();
|
||||||
// hash.put("boo", "ash");
|
////
|
||||||
// hash.put("ash", "boo");
|
//// hash.put("zoo", "ash");
|
||||||
|
//// hash.put("boo", "ash");
|
||||||
|
//// hash.put("ash", "boo");
|
||||||
|
////
|
||||||
|
//// net.getApiSignature(hash);
|
||||||
//
|
//
|
||||||
// net.getApiSignature(hash);
|
// String token = net.getToken();
|
||||||
|
//
|
||||||
String token = net.getToken();
|
// System.out.println(token);
|
||||||
|
//
|
||||||
System.out.println(token);
|
//// new Scanner(System.in).nextLine();
|
||||||
|
//
|
||||||
// new Scanner(System.in).nextLine();
|
// String key = net.getSession(token);
|
||||||
|
//
|
||||||
String key = net.getSession(token);
|
// System.out.println(key);
|
||||||
|
//
|
||||||
System.out.println(key);
|
// Scrobble scrobble = new Scrobble(1557750712, new TrackBuilder("i", new ArtistBuilder("kendrick lamar").build()).build());
|
||||||
|
//
|
||||||
Scrobble scrobble = new Scrobble(1557750712, new TrackBuilder("i", new ArtistBuilder("kendrick lamar").build()).build());
|
// net.scrobble(scrobble, key);
|
||||||
|
|
||||||
net.scrobble(scrobble, key);
|
|
||||||
|
|
||||||
assertTrue(true);
|
assertTrue(true);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user