From c048c351cf7b4e406d17f592bb8572992c2fcc44 Mon Sep 17 00:00:00 2001 From: simon Date: Sat, 25 May 2019 16:24:00 -0400 Subject: [PATCH] Release details endpoint --- .../java/net/simon987/musicgraph/Main.java | 1 + .../simon987/musicgraph/io/MusicDatabase.java | 2 +- .../musicgraph/webapi/ReleaseController.java | 36 +++++++++++++++++++ 3 files changed, 38 insertions(+), 1 deletion(-) create mode 100644 src/main/java/net/simon987/musicgraph/webapi/ReleaseController.java diff --git a/src/main/java/net/simon987/musicgraph/Main.java b/src/main/java/net/simon987/musicgraph/Main.java index 25ad897..89129f6 100644 --- a/src/main/java/net/simon987/musicgraph/Main.java +++ b/src/main/java/net/simon987/musicgraph/Main.java @@ -30,6 +30,7 @@ public class Main { rc.registerClasses(Index.class); rc.registerClasses(ArtistController.class); rc.registerClasses(CoverController.class); + rc.registerClasses(ReleaseController.class); rc.registerClasses(ChartController.class); rc.registerClasses(JacksonFeature.class); diff --git a/src/main/java/net/simon987/musicgraph/io/MusicDatabase.java b/src/main/java/net/simon987/musicgraph/io/MusicDatabase.java index ffeb3d9..5281473 100644 --- a/src/main/java/net/simon987/musicgraph/io/MusicDatabase.java +++ b/src/main/java/net/simon987/musicgraph/io/MusicDatabase.java @@ -264,7 +264,7 @@ public class MusicDatabase extends AbstractBinder { .map(x -> new Tag( (Long) x.get("id"), (String) x.get("name"), - (Long) x.get("weight") + (Double) x.get("weight") )) .collect(Collectors.toList()) ); diff --git a/src/main/java/net/simon987/musicgraph/webapi/ReleaseController.java b/src/main/java/net/simon987/musicgraph/webapi/ReleaseController.java new file mode 100644 index 0000000..90508be --- /dev/null +++ b/src/main/java/net/simon987/musicgraph/webapi/ReleaseController.java @@ -0,0 +1,36 @@ +package net.simon987.musicgraph.webapi; + +import net.simon987.musicgraph.entities.ReleaseDetails; +import net.simon987.musicgraph.io.MusicDatabase; +import net.simon987.musicgraph.logging.LogManager; + +import javax.inject.Inject; +import javax.ws.rs.GET; +import javax.ws.rs.Path; +import javax.ws.rs.PathParam; +import javax.ws.rs.Produces; +import javax.ws.rs.core.MediaType; +import java.util.logging.Logger; + +@Path("/release") +public class ReleaseController { + + private static Logger logger = LogManager.getLogger(); + + @Inject + private MusicDatabase db; + + public ReleaseController() { + } + + @GET + @Path("details/{mbid}") + @Produces(MediaType.APPLICATION_JSON) + + //TODO Should I make an endpoint only for the tags? + public ReleaseDetails getDetails(@PathParam("mbid") String mbid) { + + logger.info(String.format("Release details for %s", mbid)); + return db.getReleaseDetails(mbid); + } +}