Skip to content
Snippets Groups Projects
Commit 71d0c084 authored by koz01's avatar koz01
Browse files

Solution Mon_14-15

parent 846e590d
No related merge requests found
Pipeline #99 failed with stages
in 0 seconds
...@@ -47,6 +47,17 @@ ...@@ -47,6 +47,17 @@
<artifactId>log4j-core</artifactId> <artifactId>log4j-core</artifactId>
<version>${log4j.version}</version> <version>${log4j.version}</version>
</dependency> </dependency>
<!-- https://mvnrepository.com/artifact/org.apache.cxf/cxf-rt-rs-client -->
<dependency>
<groupId>org.apache.cxf</groupId>
<artifactId>cxf-rt-rs-client</artifactId>
<version>4.0.0</version>
</dependency>
<dependency>
<groupId>com.fasterxml.jackson.jakarta.rs</groupId>
<artifactId>jackson-jakarta-rs-json-provider</artifactId>
<version>2.14.2</version>
</dependency>
</dependencies> </dependencies>
<build> <build>
<plugins> <plugins>
......
package java2.lab12.client;
import java.util.List;
import jakarta.ws.rs.Consumes;
import jakarta.ws.rs.DELETE;
import jakarta.ws.rs.GET;
import jakarta.ws.rs.POST;
import jakarta.ws.rs.PUT;
import jakarta.ws.rs.Path;
import jakarta.ws.rs.PathParam;
import jakarta.ws.rs.Produces;
import jakarta.ws.rs.core.MediaType;
public interface CourseClient {
@POST
@Path("/course")
@Consumes(MediaType.APPLICATION_JSON)
Long createCourse(Course course);
@GET
@Produces(MediaType.APPLICATION_JSON)
@Path("/courses")
List<Course> getCourses();
@PUT
@Consumes(MediaType.APPLICATION_JSON)
@Path("/course")
void updateCourses(Course course);
@DELETE
@Path("/course/{id}")
void removeCourses(@PathParam("id") Long id);
}
...@@ -2,6 +2,12 @@ package java2.lab12.client; ...@@ -2,6 +2,12 @@ package java2.lab12.client;
import java.util.Collection; import java.util.Collection;
import java.util.Collections; import java.util.Collections;
import java.util.HashMap;
import org.apache.cxf.jaxrs.client.JAXRSClientFactory;
import com.fasterxml.jackson.databind.SerializationFeature;
import com.fasterxml.jackson.jakarta.rs.json.JacksonXmlBindJsonProvider;
import javafx.application.Application; import javafx.application.Application;
import javafx.beans.property.ReadOnlyObjectWrapper; import javafx.beans.property.ReadOnlyObjectWrapper;
...@@ -190,18 +196,26 @@ public class TableViewSample extends Application { ...@@ -190,18 +196,26 @@ public class TableViewSample extends Application {
} }
private Collection<Course> getCourses() { private Collection<Course> getCourses() {
return Collections.emptyList(); return getClient().getCourses();
} }
private void createCourse(Course course) { private void createCourse(Course course) {
// TODO Long id = getClient().createCourse(course);
course.setId(id);
} }
private void updateCourse(Course course) { private void updateCourse(Course course) {
// TODO getClient().updateCourses(course);
} }
private void removeCourse(Course course) { private void removeCourse(Course course) {
// TODO getClient().removeCourses(course.getId());
}
private static CourseClient getClient() {
return JAXRSClientFactory.create("http://localhost:8080", CourseClient.class,
Collections.singletonList(new JacksonXmlBindJsonProvider().disable(SerializationFeature.WRAP_ROOT_VALUE)
.disable(SerializationFeature.WRITE_SINGLE_ELEM_ARRAYS_UNWRAPPED)),
new HashMap<>(), true);
} }
} }
\ No newline at end of file
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment