started wiki parsing and viewing
This commit is contained in:
parent
853a8813ac
commit
167d93b30a
@ -1,7 +1,5 @@
|
|||||||
package sarsoo.fmframework.error;
|
package sarsoo.fmframework.error;
|
||||||
|
|
||||||
import sarsoo.fmframework.util.Reference;
|
|
||||||
|
|
||||||
public class ApiCallException extends Exception {
|
public class ApiCallException extends Exception {
|
||||||
|
|
||||||
private int failureCode;
|
private int failureCode;
|
||||||
|
@ -31,6 +31,7 @@ public class AlbumView extends JFrame {
|
|||||||
|
|
||||||
JButton open = new JButton("View Online");
|
JButton open = new JButton("View Online");
|
||||||
JButton viewArtist = new JButton("View Artist");
|
JButton viewArtist = new JButton("View Artist");
|
||||||
|
JButton viewWiki = new JButton("View Wiki");
|
||||||
JButton musicBrainz = new JButton("Open MusicBrainz");
|
JButton musicBrainz = new JButton("Open MusicBrainz");
|
||||||
JButton rym = new JButton("Open RYM");
|
JButton rym = new JButton("Open RYM");
|
||||||
|
|
||||||
@ -49,6 +50,8 @@ public class AlbumView extends JFrame {
|
|||||||
|
|
||||||
buttons.add(open);
|
buttons.add(open);
|
||||||
buttons.add(viewArtist);
|
buttons.add(viewArtist);
|
||||||
|
if (album.getWiki() != null)
|
||||||
|
buttons2.add(viewWiki);
|
||||||
if (album.getMbid() != null)
|
if (album.getMbid() != null)
|
||||||
buttons2.add(musicBrainz);
|
buttons2.add(musicBrainz);
|
||||||
buttons2.add(rym);
|
buttons2.add(rym);
|
||||||
@ -72,6 +75,11 @@ public class AlbumView extends JFrame {
|
|||||||
album.getArtist().view();
|
album.getArtist().view();
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
viewWiki.addActionListener(new ActionListener() {
|
||||||
|
public void actionPerformed(ActionEvent arg0) {
|
||||||
|
album.getWiki().view(album.getName());
|
||||||
|
}
|
||||||
|
});
|
||||||
musicBrainz.addActionListener(new ActionListener() {
|
musicBrainz.addActionListener(new ActionListener() {
|
||||||
public void actionPerformed(ActionEvent arg0) {
|
public void actionPerformed(ActionEvent arg0) {
|
||||||
Network.openURL(album.getMusicBrainzURL());
|
Network.openURL(album.getMusicBrainzURL());
|
||||||
|
@ -23,6 +23,7 @@ public class FMObjView extends JFrame{
|
|||||||
JLabel playCount = new JLabel();
|
JLabel playCount = new JLabel();
|
||||||
JLabel userPlayCount = new JLabel();
|
JLabel userPlayCount = new JLabel();
|
||||||
|
|
||||||
|
JButton viewWiki = new JButton("View Wiki");
|
||||||
JButton open = new JButton("View Online");
|
JButton open = new JButton("View Online");
|
||||||
JButton musicBrainz = new JButton("Open MusicBrainz");
|
JButton musicBrainz = new JButton("Open MusicBrainz");
|
||||||
|
|
||||||
@ -31,11 +32,13 @@ public class FMObjView extends JFrame{
|
|||||||
setDefaultCloseOperation(JFrame.DISPOSE_ON_CLOSE);
|
setDefaultCloseOperation(JFrame.DISPOSE_ON_CLOSE);
|
||||||
setLayout(new GridLayout(5,0));
|
setLayout(new GridLayout(5,0));
|
||||||
setSize(300, 300);
|
setSize(300, 300);
|
||||||
setResizable(false);
|
// setResizable(false);
|
||||||
|
|
||||||
buttons.setLayout(new FlowLayout());
|
buttons.setLayout(new FlowLayout());
|
||||||
|
|
||||||
buttons.add(open);
|
buttons.add(open);
|
||||||
|
if (obj.getWiki() != null)
|
||||||
|
buttons.add(viewWiki);
|
||||||
if(obj.getMbid() != null)
|
if(obj.getMbid() != null)
|
||||||
buttons.add(musicBrainz);
|
buttons.add(musicBrainz);
|
||||||
|
|
||||||
@ -47,7 +50,11 @@ public class FMObjView extends JFrame{
|
|||||||
playCount.setText(numberFormat.format(obj.getPlayCount()) + " Scrobbles");
|
playCount.setText(numberFormat.format(obj.getPlayCount()) + " Scrobbles");
|
||||||
userPlayCount.setText(numberFormat.format(obj.getUserPlayCount()) + " Your Scrobbles");
|
userPlayCount.setText(numberFormat.format(obj.getUserPlayCount()) + " Your Scrobbles");
|
||||||
|
|
||||||
|
viewWiki.addActionListener(new ActionListener() {
|
||||||
|
public void actionPerformed(ActionEvent arg0) {
|
||||||
|
obj.getWiki().view(obj.getName());
|
||||||
|
}
|
||||||
|
});
|
||||||
open.addActionListener(new ActionListener() {
|
open.addActionListener(new ActionListener() {
|
||||||
public void actionPerformed(ActionEvent arg0) {
|
public void actionPerformed(ActionEvent arg0) {
|
||||||
Network.openURL(obj.getUrl());
|
Network.openURL(obj.getUrl());
|
||||||
|
@ -29,6 +29,7 @@ public class TrackView extends JFrame {
|
|||||||
JButton open = new JButton("View Online");
|
JButton open = new JButton("View Online");
|
||||||
JButton viewArtist = new JButton("View Artist");
|
JButton viewArtist = new JButton("View Artist");
|
||||||
JButton viewAlbum = new JButton("View Album");
|
JButton viewAlbum = new JButton("View Album");
|
||||||
|
JButton viewWiki = new JButton("View Wiki");
|
||||||
JButton musicBrainz = new JButton("Open MusicBrainz");
|
JButton musicBrainz = new JButton("Open MusicBrainz");
|
||||||
JButton genius = new JButton("Open Genius");
|
JButton genius = new JButton("Open Genius");
|
||||||
|
|
||||||
@ -43,6 +44,8 @@ public class TrackView extends JFrame {
|
|||||||
buttons2.setLayout(new FlowLayout());
|
buttons2.setLayout(new FlowLayout());
|
||||||
|
|
||||||
buttons.add(open);
|
buttons.add(open);
|
||||||
|
if (track.getWiki() != null)
|
||||||
|
buttons.add(viewWiki);
|
||||||
if (track.getMbid() != null)
|
if (track.getMbid() != null)
|
||||||
buttons.add(musicBrainz);
|
buttons.add(musicBrainz);
|
||||||
buttons2.add(viewArtist);
|
buttons2.add(viewArtist);
|
||||||
@ -66,6 +69,11 @@ public class TrackView extends JFrame {
|
|||||||
Network.openURL(track.getUrl());
|
Network.openURL(track.getUrl());
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
viewWiki.addActionListener(new ActionListener() {
|
||||||
|
public void actionPerformed(ActionEvent arg0) {
|
||||||
|
track.getWiki().view(track.getName());
|
||||||
|
}
|
||||||
|
});
|
||||||
viewArtist.addActionListener(new ActionListener() {
|
viewArtist.addActionListener(new ActionListener() {
|
||||||
public void actionPerformed(ActionEvent arg0) {
|
public void actionPerformed(ActionEvent arg0) {
|
||||||
track.getArtist().view();
|
track.getArtist().view();
|
||||||
|
153
fmframework/src/sarsoo/fmframework/gui/WikiView.java
Normal file
153
fmframework/src/sarsoo/fmframework/gui/WikiView.java
Normal file
@ -0,0 +1,153 @@
|
|||||||
|
package sarsoo.fmframework.gui;
|
||||||
|
|
||||||
|
import java.awt.FlowLayout;
|
||||||
|
import java.awt.GridLayout;
|
||||||
|
import java.awt.event.ActionEvent;
|
||||||
|
import java.awt.event.ActionListener;
|
||||||
|
import java.text.NumberFormat;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Locale;
|
||||||
|
|
||||||
|
import javax.swing.JButton;
|
||||||
|
import javax.swing.JFrame;
|
||||||
|
import javax.swing.JLabel;
|
||||||
|
import javax.swing.JPanel;
|
||||||
|
|
||||||
|
import sarsoo.fmframework.music.Album;
|
||||||
|
import sarsoo.fmframework.music.FMObj;
|
||||||
|
import sarsoo.fmframework.music.Track;
|
||||||
|
import sarsoo.fmframework.music.Wiki;
|
||||||
|
import sarsoo.fmframework.net.Network;
|
||||||
|
|
||||||
|
public class WikiView extends JFrame {
|
||||||
|
// JPanel date = new JPanel();
|
||||||
|
// JPanel content = new JPanel();
|
||||||
|
// JPanel trackListPanel = new JPanel();
|
||||||
|
|
||||||
|
// JLabel dateLabel = new JLabel();
|
||||||
|
JLabel contentLabel = new JLabel();
|
||||||
|
// JLabel listeners = new JLabel();
|
||||||
|
// JLabel playCount = new JLabel();
|
||||||
|
// JLabel userPlayCount = new JLabel();
|
||||||
|
//
|
||||||
|
// JButton open = new JButton("View Online");
|
||||||
|
// JButton viewArtist = new JButton("View Artist");
|
||||||
|
// JButton viewWiki = new JButton("View Wiki");
|
||||||
|
// JButton musicBrainz = new JButton("Open MusicBrainz");
|
||||||
|
// JButton rym = new JButton("Open RYM");
|
||||||
|
|
||||||
|
public WikiView(Wiki wiki, String name) {
|
||||||
|
super(name);
|
||||||
|
setDefaultCloseOperation(JFrame.DISPOSE_ON_CLOSE);
|
||||||
|
setLayout(new GridLayout(1,1));
|
||||||
|
setSize(400, 500);
|
||||||
|
// setResizable(false);
|
||||||
|
|
||||||
|
// buttons.setLayout(new FlowLayout());
|
||||||
|
// buttons2.setLayout(new FlowLayout());
|
||||||
|
//// System.out.println(album.getName());
|
||||||
|
//// if (album.getTrackList() != null)
|
||||||
|
//// buttons2.setLayout(new GridLayout(album.getTrackList().size(), 1));
|
||||||
|
//
|
||||||
|
// buttons.add(open);
|
||||||
|
// buttons.add(viewArtist);
|
||||||
|
// if (album.getWiki() != null)
|
||||||
|
// buttons2.add(viewWiki);
|
||||||
|
// if (album.getMbid() != null)
|
||||||
|
// buttons2.add(musicBrainz);
|
||||||
|
// buttons2.add(rym);
|
||||||
|
//
|
||||||
|
// NumberFormat numberFormat = NumberFormat.getNumberInstance(Locale.US);
|
||||||
|
//
|
||||||
|
// dateLabel.setText(wiki.getDate());
|
||||||
|
contentLabel.setText("<html>" + wiki.getContent() + "<br><br>" + wiki.getDate() + "</html>");
|
||||||
|
|
||||||
|
// artist.setText(album.getArtist().getName());
|
||||||
|
// listeners.setText(numberFormat.format(album.getListeners()) + " Listeners");
|
||||||
|
// playCount.setText(numberFormat.format(album.getPlayCount()) + " Scrobbles");
|
||||||
|
// userPlayCount.setText(numberFormat.format(album.getUserPlayCount()) + " Your Scrobbles");
|
||||||
|
//
|
||||||
|
// open.addActionListener(new ActionListener() {
|
||||||
|
// public void actionPerformed(ActionEvent arg0) {
|
||||||
|
// Network.openURL(album.getUrl());
|
||||||
|
// }
|
||||||
|
// });
|
||||||
|
// viewArtist.addActionListener(new ActionListener() {
|
||||||
|
// public void actionPerformed(ActionEvent arg0) {
|
||||||
|
// album.getArtist().view();
|
||||||
|
// }
|
||||||
|
// });
|
||||||
|
// viewWiki.addActionListener(new ActionListener() {
|
||||||
|
// public void actionPerformed(ActionEvent arg0) {
|
||||||
|
// album.getWiki().view();
|
||||||
|
// }
|
||||||
|
// });
|
||||||
|
// musicBrainz.addActionListener(new ActionListener() {
|
||||||
|
// public void actionPerformed(ActionEvent arg0) {
|
||||||
|
// Network.openURL(album.getMusicBrainzURL());
|
||||||
|
// ;
|
||||||
|
// }
|
||||||
|
// });
|
||||||
|
// rym.addActionListener(new ActionListener() {
|
||||||
|
// public void actionPerformed(ActionEvent arg0) {
|
||||||
|
// Network.openURL(album.getRymURL());
|
||||||
|
// ;
|
||||||
|
// }
|
||||||
|
// });
|
||||||
|
|
||||||
|
// if (album.getTrackList() != null) {
|
||||||
|
// int counter;
|
||||||
|
// ArrayList<Track> trackList = album.getTrackList();
|
||||||
|
// for (counter = 0; counter < trackList.size(); counter++) {
|
||||||
|
// Track track = trackList.get(counter);
|
||||||
|
// JLabel name = new JLabel(track.getName());
|
||||||
|
//
|
||||||
|
// int playCountString = track.getUserPlayCount();
|
||||||
|
//
|
||||||
|
// JLabel userPlays;
|
||||||
|
// if (playCountString == 0)
|
||||||
|
// userPlays = new JLabel("0");
|
||||||
|
// else
|
||||||
|
// userPlays = new JLabel(Integer.toString(track.getUserPlayCount()));
|
||||||
|
//
|
||||||
|
// JLabel plays = new JLabel(numberFormat.format(track.getPlayCount()));
|
||||||
|
// JButton openExternal = new JButton("Open Online");
|
||||||
|
// openExternal.addActionListener(new ActionListener() {
|
||||||
|
// public void actionPerformed(ActionEvent arg0) {
|
||||||
|
// Network.openURL(track.getUrl());
|
||||||
|
// }
|
||||||
|
// });
|
||||||
|
// JButton openInternal = new JButton("Open " + track.getClass().getSimpleName());
|
||||||
|
// openInternal.addActionListener(new ActionListener() {
|
||||||
|
// public void actionPerformed(ActionEvent arg0) {
|
||||||
|
// track.view();
|
||||||
|
// }
|
||||||
|
// });
|
||||||
|
// JPanel panel = new JPanel();
|
||||||
|
// panel.setLayout(new GridLayout(1, 5));
|
||||||
|
// panel.add(name);
|
||||||
|
// panel.add(userPlays);
|
||||||
|
// panel.add(plays);
|
||||||
|
// panel.add(openInternal);
|
||||||
|
// panel.add(openExternal);
|
||||||
|
//
|
||||||
|
// trackListPanel.add(panel);
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
|
||||||
|
// add(name);
|
||||||
|
// add(artist);
|
||||||
|
// add(listeners);
|
||||||
|
// add(playCount);
|
||||||
|
// add(userPlayCount);
|
||||||
|
//
|
||||||
|
// add(trackListPanel);
|
||||||
|
// JPanel datePanel = new JPanel();
|
||||||
|
// datePanel.setLayout(new FlowLayout());
|
||||||
|
// datePanel.add(dateLabel);
|
||||||
|
|
||||||
|
// add(datePanel);
|
||||||
|
add(contentLabel);
|
||||||
|
// pack();
|
||||||
|
}
|
||||||
|
}
|
@ -5,6 +5,7 @@ import java.util.ArrayList;
|
|||||||
import org.w3c.dom.Document;
|
import org.w3c.dom.Document;
|
||||||
|
|
||||||
import sarsoo.fmframework.net.Network;
|
import sarsoo.fmframework.net.Network;
|
||||||
|
import sarsoo.fmframework.net.TestCall;
|
||||||
import sarsoo.fmframework.parser.Parser;
|
import sarsoo.fmframework.parser.Parser;
|
||||||
|
|
||||||
public class Artist extends FMObj{
|
public class Artist extends FMObj{
|
||||||
@ -24,6 +25,7 @@ public class Artist extends FMObj{
|
|||||||
|
|
||||||
public static Artist getArtist(String name, String username) {
|
public static Artist getArtist(String name, String username) {
|
||||||
String url = Network.getArtistInfoUrl(name, username);
|
String url = Network.getArtistInfoUrl(name, username);
|
||||||
|
TestCall.test(url);
|
||||||
Document response = Network.getResponse(url);
|
Document response = Network.getResponse(url);
|
||||||
Artist artist = Parser.parseArtist(response);
|
Artist artist = Parser.parseArtist(response);
|
||||||
return artist;
|
return artist;
|
||||||
|
@ -1,7 +1,44 @@
|
|||||||
package sarsoo.fmframework.music;
|
package sarsoo.fmframework.music;
|
||||||
|
|
||||||
|
import sarsoo.fmframework.gui.WikiView;
|
||||||
|
|
||||||
public class Wiki {
|
public class Wiki {
|
||||||
protected String date;
|
private String date;
|
||||||
protected String summary;
|
private String summary;
|
||||||
protected String content;
|
private String content;
|
||||||
|
|
||||||
|
public Wiki(String date, String summary, String content) {
|
||||||
|
this.setDate(date);
|
||||||
|
this.setSummary(summary);
|
||||||
|
this.setContent(content);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void view(String name) {
|
||||||
|
WikiView view = new WikiView(this, name);
|
||||||
|
view.setVisible(true);
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getDate() {
|
||||||
|
return date;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setDate(String date) {
|
||||||
|
this.date = date;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getSummary() {
|
||||||
|
return summary;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setSummary(String summary) {
|
||||||
|
this.summary = summary;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getContent() {
|
||||||
|
return content;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setContent(String content) {
|
||||||
|
this.content = content;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -29,13 +29,8 @@ public class Parser {
|
|||||||
if (doc.getDocumentElement().getAttribute("status").equals("ok")) {
|
if (doc.getDocumentElement().getAttribute("status").equals("ok")) {
|
||||||
String name = doc.getElementsByTagName("name").item(0).getTextContent();
|
String name = doc.getElementsByTagName("name").item(0).getTextContent();
|
||||||
String artist = doc.getElementsByTagName("artist").item(0).getTextContent();
|
String artist = doc.getElementsByTagName("artist").item(0).getTextContent();
|
||||||
String mbid = null;
|
|
||||||
// try {
|
|
||||||
// mbid = doc.getElementsByTagName("mbid").item(0).getTextContent();
|
|
||||||
// } catch (NullPointerException e) {
|
|
||||||
// System.err.println("Null Mbid for " + name);
|
|
||||||
// }
|
|
||||||
|
|
||||||
|
String mbid = null;
|
||||||
NodeList mbidNodeList = doc.getElementsByTagName("mbid");
|
NodeList mbidNodeList = doc.getElementsByTagName("mbid");
|
||||||
if (mbidNodeList.item(0) != null) {
|
if (mbidNodeList.item(0) != null) {
|
||||||
mbid = doc.getElementsByTagName("mbid").item(0).getTextContent();
|
mbid = doc.getElementsByTagName("mbid").item(0).getTextContent();
|
||||||
@ -46,110 +41,47 @@ public class Parser {
|
|||||||
int playCount = Integer.parseInt(doc.getElementsByTagName("playcount").item(0).getTextContent());
|
int playCount = Integer.parseInt(doc.getElementsByTagName("playcount").item(0).getTextContent());
|
||||||
|
|
||||||
int userPlayCount = 0;
|
int userPlayCount = 0;
|
||||||
// try {
|
|
||||||
// userPlayCount =
|
|
||||||
// Integer.parseInt(doc.getElementsByTagName("userplaycount").item(0).getTextContent());
|
|
||||||
// } catch (Exception e) {
|
|
||||||
// System.err.println("Couldn't parse userPlayCount, possibly unscrobbled for "
|
|
||||||
// + name);
|
|
||||||
// }
|
|
||||||
|
|
||||||
NodeList userPlayCountNodeList = doc.getElementsByTagName("userplaycount");
|
NodeList userPlayCountNodeList = doc.getElementsByTagName("userplaycount");
|
||||||
if (userPlayCountNodeList.item(0) != null) {
|
if (userPlayCountNodeList.item(0) != null) {
|
||||||
userPlayCount = Integer.parseInt(userPlayCountNodeList.item(0).getTextContent());
|
userPlayCount = Integer.parseInt(userPlayCountNodeList.item(0).getTextContent());
|
||||||
}
|
}
|
||||||
|
|
||||||
Artist artistObj = Artist.getArtist(artist, Reference.getUserName());
|
Artist artistObj = Artist.getArtist(artist, Reference.getUserName());
|
||||||
Wiki wiki = new Wiki();
|
|
||||||
|
Wiki wiki = null;
|
||||||
|
NodeList wikiNodeList = doc.getElementsByTagName("wiki");
|
||||||
|
if (wikiNodeList.item(0) != null) {
|
||||||
|
String date = wikiNodeList.item(0).getFirstChild().getTextContent();
|
||||||
|
|
||||||
|
Node summaryNode = wikiNodeList.item(0).getFirstChild().getNextSibling();
|
||||||
|
while (!(summaryNode instanceof Element) && summaryNode != null) {
|
||||||
|
summaryNode = summaryNode.getNextSibling();
|
||||||
|
}
|
||||||
|
String summary = summaryNode.getTextContent();
|
||||||
|
// System.out.println(summary);
|
||||||
|
|
||||||
|
Node contentNode = summaryNode.getNextSibling();
|
||||||
|
while (!(contentNode instanceof Element) && contentNode != null) {
|
||||||
|
contentNode = contentNode.getNextSibling();
|
||||||
|
}
|
||||||
|
String content = contentNode.getTextContent();
|
||||||
|
// System.out.println(content);
|
||||||
|
|
||||||
|
wiki = new Wiki(date, summary, content);
|
||||||
|
}
|
||||||
|
|
||||||
Album album = new Album(name, url, mbid, artistObj, listeners, playCount, userPlayCount, wiki);
|
Album album = new Album(name, url, mbid, artistObj, listeners, playCount, userPlayCount, wiki);
|
||||||
|
|
||||||
// NodeList trackListNode = doc.getElementsByTagName("tracks");
|
|
||||||
//
|
|
||||||
// NodeList child1 = doc.getElementsByTagName("tracks");
|
|
||||||
// Node sibling = trackListNode.item(0).getFirstChild();
|
|
||||||
// int counter;
|
|
||||||
// // for(counter = 0; counter < 2; counter++) {
|
|
||||||
// while (sibling != trackListNode.item(0).getLastChild()) {
|
|
||||||
// while (!(sibling instanceof Element) && sibling != null) {
|
|
||||||
// sibling = sibling.getNextSibling();
|
|
||||||
// }
|
|
||||||
// // NamedNodeMap attributes = sibling.getAttributes();
|
|
||||||
//
|
|
||||||
// // int trackNumber =
|
|
||||||
// // Integer.parseInt(attributes.getNamedItem("rank").getNodeValue());
|
|
||||||
// NodeList trackNodeList = sibling.getChildNodes();
|
|
||||||
// String trackName = trackNodeList.item(0).getTextContent();
|
|
||||||
// String artistName = trackNodeList.item(8).getFirstChild().getTextContent();
|
|
||||||
//
|
|
||||||
// Track track = Track.getTrack(trackName, artistName, Reference.getUserName());
|
|
||||||
// track.setAlbum(album);
|
|
||||||
// System.out.println(track.getName());
|
|
||||||
//
|
|
||||||
// album.addTrack(track);
|
|
||||||
//
|
|
||||||
// sibling = sibling.getNextSibling();
|
|
||||||
//
|
|
||||||
// }
|
|
||||||
// while (!(sibling instanceof Element) && sibling != null) {
|
|
||||||
// sibling = sibling.getNextSibling();
|
|
||||||
// }
|
|
||||||
|
|
||||||
// NodeList list = sibling.getChildNodes();
|
|
||||||
// list.item(0);
|
|
||||||
// System.out.println(list.item(0));
|
|
||||||
// System.out.println(trackListNode.item(0).getTextContent());
|
|
||||||
// NodeList trackNodeList = trackListNode.getChildNodes();
|
|
||||||
// if (trackListNode != null) {
|
|
||||||
// int counter = 0;
|
|
||||||
// while (trackNodeList.item(counter) != null) {
|
|
||||||
// Node track = trackNodeList.item(counter);
|
|
||||||
// // System.out.println(track.getTextContent());
|
|
||||||
// String trackName = track.getFirstChild().getTextContent();
|
|
||||||
// String trackUrl =
|
|
||||||
// track.getFirstChild().getNextSibling().getNextSibling().getTextContent();
|
|
||||||
// // String trackDuration =
|
|
||||||
// track.getFirstChild().getNextSibling().getNextSibling().getNextSibling().getNextSibling()
|
|
||||||
// .getTextContent();
|
|
||||||
// int trackNumber =
|
|
||||||
// Integer.parseInt(track.getAttributes().getNamedItem("rank").getNodeValue());
|
|
||||||
// // String trackName =
|
|
||||||
// // trackListNode.getFirstChild().getFirstChild().getTextContent();
|
|
||||||
// // String trackUrl = trackListNode.getNextSibling().getTextContent();
|
|
||||||
// System.out.println(trackUrl);
|
|
||||||
// counter++;
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
|
|
||||||
// Node wikiNode = doc.getElementsByTagName("wiki").item(0);
|
|
||||||
// String published = wikiNode.getFirstChild().getTextContent();
|
|
||||||
// String summary = wikiNode.getFirstChild().getNextSibling().getTextContent();
|
|
||||||
// String content =
|
|
||||||
// wikiNode.getFirstChild().getNextSibling().getNextSibling().getTextContent();
|
|
||||||
|
|
||||||
// System.out.println(published);
|
|
||||||
// System.out.println(summary);
|
|
||||||
// System.out.println(content);
|
|
||||||
|
|
||||||
return album;
|
return album;
|
||||||
// } catch (NullPointerException e) {
|
|
||||||
// System.err.println("Could Not Parse Album");
|
|
||||||
// return null;
|
|
||||||
// }
|
|
||||||
}
|
}
|
||||||
return null;
|
return null;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public static Artist parseArtist(Document doc) {
|
public static Artist parseArtist(Document doc) {
|
||||||
// try {
|
if (doc.getDocumentElement().getAttribute("status").equals("ok")) {
|
||||||
String name = doc.getElementsByTagName("name").item(0).getTextContent();
|
String name = doc.getElementsByTagName("name").item(0).getTextContent();
|
||||||
String mbid = null;
|
String mbid = null;
|
||||||
// try {
|
|
||||||
// mbid = doc.getElementsByTagName("mbid").item(0).getTextContent();
|
|
||||||
// } catch (NullPointerException e) {
|
|
||||||
// System.err.println("Null Mbid for " + name);
|
|
||||||
// }
|
|
||||||
|
|
||||||
NodeList mbidNodeList = doc.getElementsByTagName("mbid");
|
NodeList mbidNodeList = doc.getElementsByTagName("mbid");
|
||||||
if (mbidNodeList.item(0) != null) {
|
if (mbidNodeList.item(0) != null) {
|
||||||
@ -157,32 +89,69 @@ public class Parser {
|
|||||||
}
|
}
|
||||||
|
|
||||||
String url = doc.getElementsByTagName("url").item(0).getTextContent();
|
String url = doc.getElementsByTagName("url").item(0).getTextContent();
|
||||||
// String streamable =
|
|
||||||
// doc.getElementsByTagName("streamable").item(0).getTextContent();
|
|
||||||
int listeners = Integer.parseInt(doc.getElementsByTagName("listeners").item(0).getTextContent());
|
int listeners = Integer.parseInt(doc.getElementsByTagName("listeners").item(0).getTextContent());
|
||||||
int playCount = Integer.parseInt(doc.getElementsByTagName("playcount").item(0).getTextContent());
|
int playCount = Integer.parseInt(doc.getElementsByTagName("playcount").item(0).getTextContent());
|
||||||
|
|
||||||
int userPlayCount = 0;
|
int userPlayCount = 0;
|
||||||
// try {
|
|
||||||
// userPlayCount =
|
|
||||||
// Integer.parseInt(doc.getElementsByTagName("userplaycount").item(0).getTextContent());
|
|
||||||
// } catch (Exception e) {
|
|
||||||
// System.err.println("Couldn't parse userPlayCount, possibly unscrobbled for "
|
|
||||||
// + name);
|
|
||||||
// }
|
|
||||||
// System.out.println(listeners);
|
|
||||||
|
|
||||||
NodeList userPlayCountNodeList = doc.getElementsByTagName("userplaycount");
|
NodeList userPlayCountNodeList = doc.getElementsByTagName("userplaycount");
|
||||||
if (userPlayCountNodeList.item(0) != null) {
|
if (userPlayCountNodeList.item(0) != null) {
|
||||||
userPlayCount = Integer.parseInt(userPlayCountNodeList.item(0).getTextContent());
|
userPlayCount = Integer.parseInt(userPlayCountNodeList.item(0).getTextContent());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Wiki wiki = null;
|
||||||
|
NodeList wikiNodeList = doc.getElementsByTagName("bio");
|
||||||
|
if (wikiNodeList.getLength() != 0) {
|
||||||
|
Node wikiNode = wikiNodeList.item(0);
|
||||||
|
NodeList wikiContents = wikiNode.getChildNodes();
|
||||||
|
|
||||||
|
String date = null;
|
||||||
|
String summary = null;
|
||||||
|
String content = null;
|
||||||
|
|
||||||
|
int counter;
|
||||||
|
Node node;
|
||||||
|
for (counter = 0; counter < wikiContents.getLength(); counter++) {
|
||||||
|
node = wikiContents.item(counter);
|
||||||
|
System.out.println(node.getNodeName() + node.getTextContent());
|
||||||
|
if (node.getNodeName().equals("published")) {
|
||||||
|
date = node.getTextContent();
|
||||||
|
}
|
||||||
|
if (node.getNodeName().equals("summary")) {
|
||||||
|
summary = node.getTextContent();
|
||||||
|
}
|
||||||
|
if (node.getNodeName().equals("content")) {
|
||||||
|
content = node.getTextContent();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if(date != null && content != null)
|
||||||
|
wiki = new Wiki(date, summary, content);
|
||||||
|
// if (wikiNodeList.item(0) != null) {
|
||||||
|
// String date = wikiNodeList.item(0).getFirstChild().getTextContent();
|
||||||
|
//
|
||||||
|
// Node summaryNode = wikiNodeList.item(0).getFirstChild().getNextSibling();
|
||||||
|
// while (!(summaryNode instanceof Element) && summaryNode != null) {
|
||||||
|
// summaryNode = summaryNode.getNextSibling();
|
||||||
|
// }
|
||||||
|
// String summary = summaryNode.getTextContent();
|
||||||
|
// // System.out.println(summary);
|
||||||
|
//
|
||||||
|
// Node contentNode = summaryNode.getNextSibling();
|
||||||
|
// while (!(contentNode instanceof Element) && contentNode != null) {
|
||||||
|
// contentNode = contentNode.getNextSibling();
|
||||||
|
// }
|
||||||
|
// String content = contentNode.getTextContent();
|
||||||
|
// // System.out.println(content);
|
||||||
|
//
|
||||||
|
// wiki = new Wiki(date, summary, content);
|
||||||
|
// }
|
||||||
|
}
|
||||||
|
|
||||||
Artist artist = new Artist(name, url, mbid, listeners, playCount, userPlayCount, false, false, null);
|
Artist artist = new Artist(name, url, mbid, listeners, playCount, userPlayCount, false, false, null);
|
||||||
return artist;
|
return artist;
|
||||||
// } catch (NullPointerException e) {
|
}
|
||||||
// System.err.println("Could Not Parse Artist");
|
return null;
|
||||||
// return null;
|
|
||||||
// }
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public static Track parseTrack(Document doc) {
|
public static Track parseTrack(Document doc) {
|
||||||
@ -202,47 +171,49 @@ public class Parser {
|
|||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
String mbid = null;
|
String mbid = null;
|
||||||
// try {
|
|
||||||
// mbid = doc.getElementsByTagName("mbid").item(0).getTextContent();
|
|
||||||
// } catch (NullPointerException e) {
|
|
||||||
// System.err.println("Null Mbid for " + name + " - " + artistName);
|
|
||||||
// }
|
|
||||||
NodeList mbidNodeList = doc.getElementsByTagName("mbid");
|
NodeList mbidNodeList = doc.getElementsByTagName("mbid");
|
||||||
if (mbidNodeList.item(0) != null) {
|
if (mbidNodeList.item(0) != null) {
|
||||||
mbid = doc.getElementsByTagName("mbid").item(0).getTextContent();
|
mbid = doc.getElementsByTagName("mbid").item(0).getTextContent();
|
||||||
}
|
}
|
||||||
|
|
||||||
String url = null;
|
String url = null;
|
||||||
// try {
|
|
||||||
url = doc.getElementsByTagName("url").item(0).getTextContent();
|
url = doc.getElementsByTagName("url").item(0).getTextContent();
|
||||||
// } catch (NullPointerException e) {
|
|
||||||
// System.err.println("Could Not Parse Track Url");
|
|
||||||
// return null;
|
|
||||||
// }
|
|
||||||
int listeners = Integer.parseInt(doc.getElementsByTagName("listeners").item(0).getTextContent());
|
int listeners = Integer.parseInt(doc.getElementsByTagName("listeners").item(0).getTextContent());
|
||||||
int playCount = Integer.parseInt(doc.getElementsByTagName("playcount").item(0).getTextContent());
|
int playCount = Integer.parseInt(doc.getElementsByTagName("playcount").item(0).getTextContent());
|
||||||
|
|
||||||
int userPlayCount = 0;
|
int userPlayCount = 0;
|
||||||
// try {
|
|
||||||
// userPlayCount =
|
|
||||||
// Integer.parseInt(doc.getElementsByTagName("userplaycount").item(0).getTextContent());
|
|
||||||
// } catch (Exception e) {
|
|
||||||
// System.out.println();
|
|
||||||
// System.err.println("Couldn't parse userPlayCount, possibly unscrobbled for "
|
|
||||||
// + name);
|
|
||||||
// }
|
|
||||||
|
|
||||||
NodeList userPlayCountNodeList = doc.getElementsByTagName("userplaycount");
|
NodeList userPlayCountNodeList = doc.getElementsByTagName("userplaycount");
|
||||||
if (userPlayCountNodeList.item(0) != null) {
|
if (userPlayCountNodeList.item(0) != null) {
|
||||||
userPlayCount = Integer.parseInt(userPlayCountNodeList.item(0).getTextContent());
|
userPlayCount = Integer.parseInt(userPlayCountNodeList.item(0).getTextContent());
|
||||||
}
|
}
|
||||||
|
|
||||||
// String albumName =
|
|
||||||
// doc.getElementsByTagName("album").item(0).getTextContent();
|
|
||||||
// System.out.println(albumName);
|
|
||||||
Artist artistObj = Artist.getArtist(artistName, Reference.getUserName());
|
Artist artistObj = Artist.getArtist(artistName, Reference.getUserName());
|
||||||
|
|
||||||
// System.out.println(userPlayCount);
|
Wiki wiki = null;
|
||||||
|
NodeList wikiNodeList = doc.getElementsByTagName("wiki");
|
||||||
|
if (wikiNodeList.item(0) != null) {
|
||||||
|
String date = wikiNodeList.item(0).getFirstChild().getTextContent();
|
||||||
|
|
||||||
|
Node summaryNode = wikiNodeList.item(0).getFirstChild().getNextSibling();
|
||||||
|
while (!(summaryNode instanceof Element) && summaryNode != null) {
|
||||||
|
summaryNode = summaryNode.getNextSibling();
|
||||||
|
}
|
||||||
|
String summary = summaryNode.getTextContent();
|
||||||
|
// System.out.println(summary);
|
||||||
|
|
||||||
|
Node contentNode = summaryNode.getNextSibling();
|
||||||
|
while (!(contentNode instanceof Element) && contentNode != null) {
|
||||||
|
contentNode = contentNode.getNextSibling();
|
||||||
|
}
|
||||||
|
String content = contentNode.getTextContent();
|
||||||
|
// System.out.println(content);
|
||||||
|
|
||||||
|
wiki = new Wiki(date, summary, content);
|
||||||
|
}
|
||||||
|
|
||||||
Track track = new Track(name, url, mbid, artistObj, listeners, playCount, userPlayCount, null);
|
Track track = new Track(name, url, mbid, artistObj, listeners, playCount, userPlayCount, null);
|
||||||
return track;
|
return track;
|
||||||
@ -253,27 +224,20 @@ public class Parser {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public static Track parseLastTrack(Document doc) {
|
public static Track parseLastTrack(Document doc) {
|
||||||
// try {
|
|
||||||
// System.out.println(doc.getDocumentElement().getAttribute("status"));
|
|
||||||
if (doc.getDocumentElement().getAttribute("status").equals("ok")) {
|
if (doc.getDocumentElement().getAttribute("status").equals("ok")) {
|
||||||
String name = doc.getElementsByTagName("name").item(0).getTextContent();
|
String name = doc.getElementsByTagName("name").item(0).getTextContent();
|
||||||
// System.out.println(name);
|
// System.out.println(name);
|
||||||
String artistName = doc.getElementsByTagName("artist").item(0).getTextContent();
|
String artistName = doc.getElementsByTagName("artist").item(0).getTextContent();
|
||||||
|
|
||||||
String albumName = doc.getElementsByTagName("album").item(0).getTextContent();
|
String albumName = doc.getElementsByTagName("album").item(0).getTextContent();
|
||||||
System.out.println(albumName);
|
// System.out.println(albumName);
|
||||||
Track track = Track.getTrack(name, artistName, Reference.getUserName());
|
Track track = Track.getTrack(name, artistName, Reference.getUserName());
|
||||||
|
|
||||||
Album album = Album.getAlbum(albumName, artistName, Reference.getUserName());
|
Album album = Album.getAlbum(albumName, artistName, Reference.getUserName());
|
||||||
|
|
||||||
// if (album.getName() != null)
|
|
||||||
track.setAlbum(album);
|
track.setAlbum(album);
|
||||||
|
|
||||||
return track;
|
return track;
|
||||||
// } catch (NullPointerException e) {
|
|
||||||
// System.err.println("Could Not Parse Last Track");
|
|
||||||
// return null;
|
|
||||||
// }
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return null;
|
return null;
|
||||||
|
@ -8,6 +8,7 @@ import sarsoo.fmframework.music.Album;
|
|||||||
import sarsoo.fmframework.music.Artist;
|
import sarsoo.fmframework.music.Artist;
|
||||||
import sarsoo.fmframework.music.Track;
|
import sarsoo.fmframework.music.Track;
|
||||||
import sarsoo.fmframework.net.Network;
|
import sarsoo.fmframework.net.Network;
|
||||||
|
import sarsoo.fmframework.net.TestCall;
|
||||||
import sarsoo.fmframework.parser.Parser;
|
import sarsoo.fmframework.parser.Parser;
|
||||||
|
|
||||||
public class GetObject {
|
public class GetObject {
|
||||||
@ -33,12 +34,18 @@ public class GetObject {
|
|||||||
public static Track getLastTrack() {
|
public static Track getLastTrack() {
|
||||||
|
|
||||||
String url = Network.getLastTrackUrl(Reference.getUserName());
|
String url = Network.getLastTrackUrl(Reference.getUserName());
|
||||||
|
// TestCall.test(url);
|
||||||
Document doc = Network.getResponse(url);
|
Document doc = Network.getResponse(url);
|
||||||
|
|
||||||
// System.out.println(doc.getDocumentElement().getAttribute("status"));
|
// System.out.println(doc.getDocumentElement().getAttribute("status"));
|
||||||
|
if (doc != null) {
|
||||||
|
// System.out.println(doc.getDocumentElement().getAttribute("status"));
|
||||||
Parser.stripSpace(doc.getDocumentElement());
|
Parser.stripSpace(doc.getDocumentElement());
|
||||||
Track track = Parser.parseLastTrack(doc);
|
Track track = Parser.parseLastTrack(doc);
|
||||||
// return null;
|
// return null;
|
||||||
return track;
|
return track;
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user