-
Notifications
You must be signed in to change notification settings - Fork 2k
Expand file tree
/
Copy pathMovieRatingService.java
More file actions
102 lines (89 loc) · 3.77 KB
/
MovieRatingService.java
File metadata and controls
102 lines (89 loc) · 3.77 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
package io.vertx.example.virtualthreads;
import io.vertx.core.*;
import io.vertx.core.json.JsonObject;
import io.vertx.ext.web.Router;
import io.vertx.ext.web.RoutingContext;
import io.vertx.jdbcclient.JDBCConnectOptions;
import io.vertx.jdbcclient.JDBCPool;
import io.vertx.sqlclient.*;
import java.util.Arrays;
import java.util.List;
public class MovieRatingService extends VerticleBase {
public static void main(String[] args) {
var vertx = Vertx.vertx();
vertx.deployVerticle(MovieRatingService.class, new DeploymentOptions().setThreadingModel(ThreadingModel.VIRTUAL_THREAD))
.await();
System.out.println("Server started");
}
private static final List<String> DB_STATEMENTS = Arrays.asList(
"CREATE TABLE MOVIE (ID VARCHAR(16) PRIMARY KEY, TITLE VARCHAR(256) NOT NULL)",
"CREATE TABLE RATING (ID INTEGER IDENTITY PRIMARY KEY, value INTEGER, MOVIE_ID VARCHAR(16))",
"INSERT INTO MOVIE (ID, TITLE) VALUES 'starwars', 'Star Wars'",
"INSERT INTO MOVIE (ID, TITLE) VALUES 'indianajones', 'Indiana Jones'",
"INSERT INTO RATING (VALUE, MOVIE_ID) VALUES 1, 'starwars'",
"INSERT INTO RATING (VALUE, MOVIE_ID) VALUES 5, 'starwars'",
"INSERT INTO RATING (VALUE, MOVIE_ID) VALUES 9, 'starwars'",
"INSERT INTO RATING (VALUE, MOVIE_ID) VALUES 10, 'starwars'",
"INSERT INTO RATING (VALUE, MOVIE_ID) VALUES 4, 'indianajones'",
"INSERT INTO RATING (VALUE, MOVIE_ID) VALUES 7, 'indianajones'",
"INSERT INTO RATING (VALUE, MOVIE_ID) VALUES 3, 'indianajones'",
"INSERT INTO RATING (VALUE, MOVIE_ID) VALUES 9, 'indianajones'"
);
private SqlClient client;
@Override
public Future<?> start() {
client = JDBCPool.pool(vertx,
new JDBCConnectOptions().setJdbcUrl("jdbc:hsqldb:mem:test?shutdown=true"),
new PoolOptions().setMaxSize(30));
DB_STATEMENTS.forEach(statement -> {
client.query(statement).execute().await();
});
// Build Vert.x Web router
var router = Router.router(vertx);
router.get("/movie/:id").handler(this::getMovie);
router.get("/rateMovie/:id").handler(this::rateMovie);
router.get("/getRating/:id").handler(this::getRating);
// Start the server
return vertx.createHttpServer()
.requestHandler(router)
.listen(config().getInteger("http.port", 8080));
}
// Send info about a movie
private void getMovie(RoutingContext ctx) {
var id = ctx.pathParam("id");
var rows = client.preparedQuery("SELECT TITLE FROM MOVIE WHERE ID=?").execute(Tuple.of(id)).await();
if (rows.size() == 1) {
ctx.response()
.putHeader("Content-Type", "application/json")
.end(new JsonObject()
.put("id", id)
.put("title", rows.iterator().next().getString("TITLE"))
.encode());
} else {
ctx.response().setStatusCode(404).end();
}
}
// Rate a movie
private void rateMovie(RoutingContext ctx) {
var movie = ctx.pathParam("id");
var rating = Integer.parseInt(ctx.queryParam("rating").get(0));
RowSet<Row> rows = client.preparedQuery("SELECT TITLE FROM MOVIE WHERE ID=?").execute(Tuple.of(movie)).await();
if (rows.size() == 1) {
client.preparedQuery("INSERT INTO RATING (VALUE, MOVIE_ID) VALUES ?, ?").execute(Tuple.of(rating, movie)).await();
ctx.response().setStatusCode(200).end();
} else {
ctx.response().setStatusCode(404).end();
}
}
// Get the current rating of a movie
private void getRating(RoutingContext ctx) {
var id = ctx.pathParam("id");
var rows = client.preparedQuery("SELECT AVG(VALUE) AS VALUE FROM RATING WHERE MOVIE_ID=?").execute(Tuple.of(id)).await();
ctx.response()
.putHeader("Content-Type", "application/json")
.end(new JsonObject()
.put("id", id)
.put("title", rows.iterator().next().getDouble("VALUE"))
.encode());
}
}