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

solution

parent 846e590d
No related merge requests found
Pipeline #93 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; package java2.lab12.client;
import jakarta.xml.bind.annotation.XmlRootElement;
import lombok.Getter; import lombok.Getter;
import lombok.Setter; import lombok.Setter;
import lombok.ToString; import lombok.ToString;
@XmlRootElement
@ToString @ToString
public class Course { public class Course {
......
package java2.lab12.client;
import java.util.List;
import jakarta.ws.rs.Consumes;
import jakarta.ws.rs.GET;
import jakarta.ws.rs.POST;
import jakarta.ws.rs.PUT;
import jakarta.ws.rs.Path;
import jakarta.ws.rs.Produces;
import jakarta.ws.rs.core.MediaType;
public interface CourseClient {
@GET
@Path("/courses")
@Produces(MediaType.APPLICATION_JSON)
List<Course> getAll();
@PUT
@Path("/course")
@Consumes(MediaType.APPLICATION_JSON)
void update(Course course);
@POST
@Path("/course")
@Consumes(MediaType.APPLICATION_JSON)
Long create(Course course);
}
...@@ -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,25 @@ public class TableViewSample extends Application { ...@@ -190,18 +196,25 @@ public class TableViewSample extends Application {
} }
private Collection<Course> getCourses() { private Collection<Course> getCourses() {
return Collections.emptyList(); return getClient().getAll();
} }
private void createCourse(Course course) { private void createCourse(Course course) {
// TODO getClient().create(course);
} }
private void updateCourse(Course course) { private void updateCourse(Course course) {
// TODO getClient().update(course);
} }
private void removeCourse(Course course) { private void removeCourse(Course course) {
// TODO // TODO
} }
private 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