added scrobble and get recent tracks
This commit is contained in:
parent
1e77a32b94
commit
26c9e2d17a
@ -267,7 +267,8 @@ public class FmNetwork {
|
|||||||
try {
|
try {
|
||||||
builder.setPlayCount(trackJson.getInt("playcount"));
|
builder.setPlayCount(trackJson.getInt("playcount"));
|
||||||
} catch (JSONException e) {
|
} catch (JSONException e) {
|
||||||
log.logInfo(new InfoEntry("getTrack").addArg("no play count for").addArg(nameIn).addArg(e.getMessage()));
|
log.logInfo(
|
||||||
|
new InfoEntry("getTrack").addArg("no play count for").addArg(nameIn).addArg(e.getMessage()));
|
||||||
}
|
}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
@ -392,7 +393,9 @@ public class FmNetwork {
|
|||||||
return new JSONObject(response.getBody().toString());
|
return new JSONObject(response.getBody().toString());
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
Logger.getLog().logError(new ErrorEntry("HTTP Get").setErrorCode(response.getStatus()));
|
JSONObject obj = new JSONObject(response.getBody().toString());
|
||||||
|
Logger.getLog().logError(new ErrorEntry("HTTP Get").setErrorCode(response.getStatus())
|
||||||
|
.addArg(Integer.toString(obj.getInt("error"))).addArg(obj.getString("message")));
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
} catch (UnirestException e) {
|
} catch (UnirestException e) {
|
||||||
|
@ -11,9 +11,14 @@ import org.json.JSONObject;
|
|||||||
import sarsoo.fmframework.log.Logger;
|
import sarsoo.fmframework.log.Logger;
|
||||||
import sarsoo.fmframework.log.entry.InfoEntry;
|
import sarsoo.fmframework.log.entry.InfoEntry;
|
||||||
import sarsoo.fmframework.log.entry.LogEntry;
|
import sarsoo.fmframework.log.entry.LogEntry;
|
||||||
|
import sarsoo.fmframework.music.Album;
|
||||||
|
import sarsoo.fmframework.music.Album.AlbumBuilder;
|
||||||
import sarsoo.fmframework.music.Artist;
|
import sarsoo.fmframework.music.Artist;
|
||||||
|
import sarsoo.fmframework.music.Artist.ArtistBuilder;
|
||||||
|
import sarsoo.fmframework.music.Scrobble;
|
||||||
import sarsoo.fmframework.music.Tag;
|
import sarsoo.fmframework.music.Tag;
|
||||||
import sarsoo.fmframework.music.Track;
|
import sarsoo.fmframework.music.Track;
|
||||||
|
import sarsoo.fmframework.music.Track.TrackBuilder;
|
||||||
import sarsoo.fmframework.util.FMObjList;
|
import sarsoo.fmframework.util.FMObjList;
|
||||||
|
|
||||||
public class FmUserNetwork extends FmNetwork {
|
public class FmUserNetwork extends FmNetwork {
|
||||||
@ -225,6 +230,52 @@ public class FmUserNetwork extends FmNetwork {
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public ArrayList<Scrobble> getRecentTracks(int number) {
|
||||||
|
int limit = 50;
|
||||||
|
|
||||||
|
int pages = 0;
|
||||||
|
|
||||||
|
System.out.println(number / limit);
|
||||||
|
if ((double) number % (double) limit != 0) {
|
||||||
|
pages = (number / limit) + 1;
|
||||||
|
} else {
|
||||||
|
pages = number / limit;
|
||||||
|
}
|
||||||
|
|
||||||
|
ArrayList<Scrobble> scrobbles = new ArrayList<Scrobble>();
|
||||||
|
int counter;
|
||||||
|
for (counter = 0; counter < pages; counter++) {
|
||||||
|
|
||||||
|
HashMap<String, String> parameters = new HashMap<String, String>();
|
||||||
|
|
||||||
|
parameters.put("user", userName);
|
||||||
|
parameters.put("limit", Integer.toString(limit));
|
||||||
|
parameters.put("page", Integer.toString(counter + 1));
|
||||||
|
|
||||||
|
JSONObject obj = makeGetRequest("user.getrecenttracks", parameters);
|
||||||
|
|
||||||
|
JSONArray tracks = obj.getJSONObject("recenttracks").getJSONArray("track");
|
||||||
|
|
||||||
|
for (int i = 0; i < tracks.length(); i++) {
|
||||||
|
JSONObject json = (JSONObject) tracks.get(i);
|
||||||
|
|
||||||
|
if (scrobbles.size() < number) {
|
||||||
|
Artist artist = new ArtistBuilder(json.getJSONObject("artist").getString("#text")).build();
|
||||||
|
Album album = new AlbumBuilder(json.getJSONObject("album").getString("#text"), artist).build();
|
||||||
|
|
||||||
|
Track track = new TrackBuilder(json.getString("name"), artist).build();
|
||||||
|
track.setAlbum(album);
|
||||||
|
|
||||||
|
Scrobble scrobble = new Scrobble(json.getJSONObject("date").getLong("uts"), track);
|
||||||
|
|
||||||
|
scrobbles.add(scrobble);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return scrobbles;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns list of user tags
|
* Returns list of user tags
|
||||||
*
|
*
|
||||||
|
@ -4,7 +4,7 @@ import java.util.ArrayList;
|
|||||||
|
|
||||||
public class ErrorEntry extends LogEntry {
|
public class ErrorEntry extends LogEntry {
|
||||||
|
|
||||||
protected int errorCode;
|
protected int errorCode = 0;
|
||||||
|
|
||||||
public ErrorEntry(String methodIn) {
|
public ErrorEntry(String methodIn) {
|
||||||
super(methodIn);
|
super(methodIn);
|
||||||
@ -29,7 +29,7 @@ public class ErrorEntry extends LogEntry {
|
|||||||
String logString = String.format("%s !!%s", timestamp, method);
|
String logString = String.format("%s !!%s", timestamp, method);
|
||||||
|
|
||||||
if (errorCode != 0) {
|
if (errorCode != 0) {
|
||||||
logString += String.format(" (%i)", errorCode);
|
logString += String.format(" (%d)", errorCode);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (args != null) {
|
if (args != null) {
|
||||||
|
@ -18,4 +18,8 @@ public class Scrobble {
|
|||||||
return track;
|
return track;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public String toString() {
|
||||||
|
return utc + " " + track.toString();
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -20,6 +20,7 @@ public class Track extends FMObj implements Serializable {
|
|||||||
protected int duration;
|
protected int duration;
|
||||||
protected boolean isLoved;
|
protected boolean isLoved;
|
||||||
protected ArrayList<Tag> tagList;
|
protected ArrayList<Tag> tagList;
|
||||||
|
protected ArrayList<Scrobble> scrobbles;
|
||||||
|
|
||||||
private int utsFirstListen;
|
private int utsFirstListen;
|
||||||
|
|
||||||
@ -44,6 +45,8 @@ public class Track extends FMObj implements Serializable {
|
|||||||
this.isLoved = builder.isLoved;
|
this.isLoved = builder.isLoved;
|
||||||
this.tagList = builder.tagList;
|
this.tagList = builder.tagList;
|
||||||
|
|
||||||
|
this.scrobbles = new ArrayList<Scrobble>();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public Artist getArtist() {
|
public Artist getArtist() {
|
||||||
@ -74,6 +77,14 @@ public class Track extends FMObj implements Serializable {
|
|||||||
return album;
|
return album;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void addScrobble(Scrobble scrobble) {
|
||||||
|
scrobbles.add(scrobble);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setScrobbles(ArrayList<Scrobble> scrobble) {
|
||||||
|
scrobbles = scrobble;
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean equals(Object obj) {
|
public boolean equals(Object obj) {
|
||||||
if (obj.getClass() != this.getClass())
|
if (obj.getClass() != this.getClass())
|
||||||
|
@ -2,10 +2,13 @@ package sarsoo.fmframework.fm;
|
|||||||
|
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
|
import sarsoo.fmframework.music.Scrobble;
|
||||||
import sarsoo.fmframework.net.Key;
|
import sarsoo.fmframework.net.Key;
|
||||||
|
|
||||||
import static org.junit.Assert.*;
|
import static org.junit.Assert.*;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
|
||||||
public class FmUserNetworkTest {
|
public class FmUserNetworkTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
@ -17,4 +20,13 @@ public class FmUserNetworkTest {
|
|||||||
public void testGetLastTrack() {
|
public void testGetLastTrack() {
|
||||||
assertNotNull(new FmUserNetwork(Key.getKey(), "sarsoo").getLastTrack());
|
assertNotNull(new FmUserNetwork(Key.getKey(), "sarsoo").getLastTrack());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testGetRecentTracks() {
|
||||||
|
FmUserNetwork net = new FmUserNetwork(Key.getKey(), "sarsoo");
|
||||||
|
ArrayList<Scrobble> scrobbles = net.getRecentTracks(50);
|
||||||
|
scrobbles.stream().forEach(System.out::println);
|
||||||
|
System.out.println(scrobbles.size());
|
||||||
|
assertNotNull(1);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user