Improved code style, added debug XML output
This commit is contained in:
parent
7f32cd9072
commit
b96f28921e
@ -7,10 +7,12 @@ import javax.ws.rs.client.ClientBuilder;
|
|||||||
import javax.ws.rs.client.Entity;
|
import javax.ws.rs.client.Entity;
|
||||||
import javax.ws.rs.client.WebTarget;
|
import javax.ws.rs.client.WebTarget;
|
||||||
import javax.ws.rs.core.Response;
|
import javax.ws.rs.core.Response;
|
||||||
|
import javax.xml.bind.JAXBContext;
|
||||||
|
import javax.xml.bind.JAXBException;
|
||||||
|
import javax.xml.bind.Marshaller;
|
||||||
import javax.xml.datatype.DatatypeConfigurationException;
|
import javax.xml.datatype.DatatypeConfigurationException;
|
||||||
import javax.xml.datatype.DatatypeFactory;
|
import javax.xml.datatype.DatatypeFactory;
|
||||||
|
|
||||||
import envoy.client.ui.ChatWindow;
|
|
||||||
import envoy.schema.Message;
|
import envoy.schema.Message;
|
||||||
import envoy.schema.ObjectFactory;
|
import envoy.schema.ObjectFactory;
|
||||||
|
|
||||||
@ -43,21 +45,39 @@ public class EnvoyClient {
|
|||||||
* @param textContent Content (text) of the message
|
* @param textContent Content (text) of the message
|
||||||
*/
|
*/
|
||||||
public void sendMessage(Message message) {
|
public void sendMessage(Message message) {
|
||||||
//System.out.println(message.getContent().get(0).getText());
|
|
||||||
new Thread(() -> {
|
new Thread(() -> {
|
||||||
Client client = ClientBuilder.newClient();
|
// Print message XML to console
|
||||||
WebTarget target = client.target("http://localhost:8080/envoy-server/rest/message/send");
|
JAXBContext jc;
|
||||||
Response response = target.request().post(Entity.entity(message, "application/xml"));
|
try {
|
||||||
|
jc = JAXBContext.newInstance("envoy.schema");
|
||||||
|
Marshaller m = jc.createMarshaller();
|
||||||
|
m.setProperty(Marshaller.JAXB_FORMATTED_OUTPUT, true);
|
||||||
|
m.marshal(message, System.out);
|
||||||
|
} catch (JAXBException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
|
||||||
|
// Send message
|
||||||
|
Client client = ClientBuilder.newClient();
|
||||||
|
WebTarget target = client.target("http://kske.feste-ip.net:43315/envoy-server/rest/message/send");
|
||||||
|
Response response = target.request().post(Entity.entity(message, "application/xml"));
|
||||||
System.out.println("Response code: " + response.getStatus());
|
System.out.println("Response code: " + response.getStatus());
|
||||||
response.close();
|
response.close();
|
||||||
client.close();
|
client.close();
|
||||||
}).start();
|
}).start();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates a {@link Message} object serializable to XML.
|
||||||
|
*
|
||||||
|
* @param senderID The ID of the sender
|
||||||
|
* @param recipientID The ID of the recipient
|
||||||
|
* @param textContent The content (text) of the message
|
||||||
|
* @return Prepared {@link Message} object
|
||||||
|
*/
|
||||||
public Message createMessage(String senderID, String recipientID, String textContent) {
|
public Message createMessage(String senderID, String recipientID, String textContent) {
|
||||||
ObjectFactory factory = new ObjectFactory();
|
ObjectFactory factory = new ObjectFactory();
|
||||||
Message.MetaData metaData = factory.createMessageMetaData();
|
Message.MetaData metaData = factory.createMessageMetaData();
|
||||||
metaData.setSender(senderID);
|
metaData.setSender(senderID);
|
||||||
metaData.setRecipient(recipientID);
|
metaData.setRecipient(recipientID);
|
||||||
metaData.setState(false);
|
metaData.setState(false);
|
||||||
@ -71,7 +91,6 @@ public class EnvoyClient {
|
|||||||
message.setMetaData(metaData);
|
message.setMetaData(metaData);
|
||||||
message.getContent().add(content);
|
message.getContent().add(content);
|
||||||
|
|
||||||
|
|
||||||
return message;
|
return message;
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -1,14 +1,12 @@
|
|||||||
package envoy.client.ui;
|
package envoy.client.ui;
|
||||||
|
|
||||||
import java.awt.Color;
|
import java.awt.Color;
|
||||||
import java.awt.Component;
|
import java.awt.ComponentOrientation;
|
||||||
import java.awt.EventQueue;
|
import java.awt.EventQueue;
|
||||||
import java.awt.Font;
|
import java.awt.Font;
|
||||||
import java.awt.GridBagConstraints;
|
import java.awt.GridBagConstraints;
|
||||||
import java.awt.GridBagLayout;
|
import java.awt.GridBagLayout;
|
||||||
import java.awt.Insets;
|
import java.awt.Insets;
|
||||||
import java.util.Iterator;
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
import javax.swing.DefaultListModel;
|
import javax.swing.DefaultListModel;
|
||||||
import javax.swing.JButton;
|
import javax.swing.JButton;
|
||||||
@ -18,39 +16,26 @@ import javax.swing.JOptionPane;
|
|||||||
import javax.swing.JPanel;
|
import javax.swing.JPanel;
|
||||||
import javax.swing.JScrollPane;
|
import javax.swing.JScrollPane;
|
||||||
import javax.swing.JTextArea;
|
import javax.swing.JTextArea;
|
||||||
import javax.swing.ListModel;
|
|
||||||
import javax.swing.border.Border;
|
|
||||||
import javax.swing.border.EmptyBorder;
|
import javax.swing.border.EmptyBorder;
|
||||||
import javax.swing.border.LineBorder;
|
|
||||||
import javax.swing.border.MatteBorder;
|
|
||||||
|
|
||||||
import envoy.client.EnvoyClient;
|
import envoy.client.EnvoyClient;
|
||||||
import envoy.schema.Message;
|
import envoy.schema.Message;
|
||||||
|
|
||||||
import javax.swing.ListSelectionModel;
|
|
||||||
import javax.swing.UIManager;
|
|
||||||
|
|
||||||
import java.awt.Rectangle;
|
|
||||||
import java.awt.geom.RoundRectangle2D;
|
|
||||||
import java.awt.ComponentOrientation;
|
|
||||||
import java.awt.Point;
|
|
||||||
import java.awt.Dimension;
|
|
||||||
import javax.swing.border.BevelBorder;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Project: <strong>envoy-client</strong><br>
|
* Project: <strong>envoy-client</strong><br>
|
||||||
* File: <strong>ChatWindow.java</strong><br>
|
* File: <strong>ChatWindow.java</strong><br>
|
||||||
* Created: <strong>28 Sep 2019</strong><br>
|
* Created: <strong>28 Sep 2019</strong><br>
|
||||||
* Author: <strong>Maximilian Käfer & Kai S. K. Engelbart & Leon Hofmeister</strong>
|
* Author: <strong>Maximilian Käfer & Kai S. K. Engelbart</strong>
|
||||||
*/
|
*/
|
||||||
public class ChatWindow extends JFrame {
|
public class ChatWindow extends JFrame {
|
||||||
|
|
||||||
private static final long serialVersionUID = 6865098428255463649L;
|
private static final long serialVersionUID = 6865098428255463649L;
|
||||||
|
|
||||||
private JPanel contentPane = new JPanel();
|
private JPanel contentPane = new JPanel();
|
||||||
private EnvoyClient envoyClient = new EnvoyClient();
|
private EnvoyClient envoyClient = new EnvoyClient();
|
||||||
|
|
||||||
public DefaultListModel<String> listModel = new DefaultListModel<>();
|
public DefaultListModel<String> listModel = new DefaultListModel<>();
|
||||||
|
|
||||||
public ChatWindow() {
|
public ChatWindow() {
|
||||||
setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
|
setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
|
||||||
setBounds(100, 100, 600, 800);
|
setBounds(100, 100, 600, 800);
|
||||||
@ -62,16 +47,12 @@ public class ChatWindow extends JFrame {
|
|||||||
contentPane.setBorder(new EmptyBorder(5, 5, 5, 5));
|
contentPane.setBorder(new EmptyBorder(5, 5, 5, 5));
|
||||||
setContentPane(contentPane);
|
setContentPane(contentPane);
|
||||||
GridBagLayout gbl_contentPane = new GridBagLayout();
|
GridBagLayout gbl_contentPane = new GridBagLayout();
|
||||||
gbl_contentPane.columnWidths = new int[] { 1, 1, 1 };
|
gbl_contentPane.columnWidths = new int[] { 1, 1, 1 };
|
||||||
gbl_contentPane.rowHeights = new int[] { 1, 1, 1 };
|
gbl_contentPane.rowHeights = new int[] { 1, 1, 1 };
|
||||||
gbl_contentPane.columnWeights = new double[] { 0.3, 1.0, 0.1 };
|
gbl_contentPane.columnWeights = new double[] { 0.3, 1.0, 0.1 };
|
||||||
gbl_contentPane.rowWeights = new double[] { 0.05, 1, 0.07 };
|
gbl_contentPane.rowWeights = new double[] { 0.05, 1, 0.07 };
|
||||||
contentPane.setLayout(gbl_contentPane);
|
contentPane.setLayout(gbl_contentPane);
|
||||||
|
|
||||||
|
|
||||||
// Chat------------------
|
|
||||||
List<Message> testMessages = List.of(envoyClient.createMessage("UserA", "UserB", "Das ist eine Testnachricht."), envoyClient.createMessage("UserB", "UserA", "Das ist die Antwort auf die Testnachricht."));
|
|
||||||
|
|
||||||
JList<String> elementList = new JList<>();
|
JList<String> elementList = new JList<>();
|
||||||
elementList.setFocusTraversalKeysEnabled(false);
|
elementList.setFocusTraversalKeysEnabled(false);
|
||||||
|
|
||||||
@ -81,21 +62,11 @@ public class ChatWindow extends JFrame {
|
|||||||
elementList.setForeground(new Color(255, 255, 255));
|
elementList.setForeground(new Color(255, 255, 255));
|
||||||
elementList.setBackground(new Color(51, 51, 51));
|
elementList.setBackground(new Color(51, 51, 51));
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
elementList.setModel(listModel);
|
elementList.setModel(listModel);
|
||||||
elementList.setFont( new Font("Arial", Font.PLAIN, 17));
|
elementList.setFont(new Font("Arial", Font.PLAIN, 17));
|
||||||
elementList.setFixedCellHeight(60);
|
elementList.setFixedCellHeight(60);
|
||||||
elementList.setBorder(new EmptyBorder(5, 5, 5, 5));
|
elementList.setBorder(new EmptyBorder(5, 5, 5, 5));
|
||||||
|
|
||||||
|
|
||||||
//Only temporary for the predefined messages in the List
|
|
||||||
for (int i = 0; i < testMessages.size(); i++) {
|
|
||||||
listModel.addElement("<html>" + "<p style=\"color:#d2d235\"> <b> <small>" + getSenderElement(testMessages.get(i)) + "</b> </small>" + "<br>" + "<p style=\"color:white\">" + getFirstContentElement(testMessages.get(i)) + "</span></html>");
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
JScrollPane scrollPane = new JScrollPane();
|
JScrollPane scrollPane = new JScrollPane();
|
||||||
scrollPane.setForeground(new Color(0, 0, 0));
|
scrollPane.setForeground(new Color(0, 0, 0));
|
||||||
scrollPane.setBackground(new Color(51, 51, 51));
|
scrollPane.setBackground(new Color(51, 51, 51));
|
||||||
@ -103,40 +74,35 @@ public class ChatWindow extends JFrame {
|
|||||||
scrollPane.setBorder(null);
|
scrollPane.setBorder(null);
|
||||||
|
|
||||||
GridBagConstraints gbc_scrollPane = new GridBagConstraints();
|
GridBagConstraints gbc_scrollPane = new GridBagConstraints();
|
||||||
gbc_scrollPane.fill = GridBagConstraints.BOTH;
|
gbc_scrollPane.fill = GridBagConstraints.BOTH;
|
||||||
gbc_scrollPane.gridwidth = 2;
|
gbc_scrollPane.gridwidth = 2;
|
||||||
gbc_scrollPane.gridx = 1;
|
gbc_scrollPane.gridx = 1;
|
||||||
gbc_scrollPane.gridy = 1;
|
gbc_scrollPane.gridy = 1;
|
||||||
|
|
||||||
|
|
||||||
gbc_scrollPane.insets = new Insets(10, 10, 10, 10);
|
gbc_scrollPane.insets = new Insets(10, 10, 10, 10);
|
||||||
|
|
||||||
contentPane.add(scrollPane, gbc_scrollPane);
|
contentPane.add(scrollPane, gbc_scrollPane);
|
||||||
|
|
||||||
|
// Message enter field
|
||||||
// Message enter field-----------------
|
|
||||||
JTextArea messageEnterTextfield = new JTextArea();
|
JTextArea messageEnterTextfield = new JTextArea();
|
||||||
messageEnterTextfield.setCaretColor(new Color(255, 255, 255));
|
messageEnterTextfield.setCaretColor(new Color(255, 255, 255));
|
||||||
messageEnterTextfield.setForeground(new Color(255, 255, 255));
|
messageEnterTextfield.setForeground(new Color(255, 255, 255));
|
||||||
messageEnterTextfield.setBackground(new Color(51, 51, 51));
|
messageEnterTextfield.setBackground(new Color(51, 51, 51));
|
||||||
messageEnterTextfield.setLineWrap(true);
|
messageEnterTextfield.setLineWrap(true);
|
||||||
messageEnterTextfield.setBorder(null);
|
messageEnterTextfield.setBorder(null);
|
||||||
messageEnterTextfield.setFont( new Font("Arial", Font.PLAIN, 17));
|
messageEnterTextfield.setFont(new Font("Arial", Font.PLAIN, 17));
|
||||||
messageEnterTextfield.setBorder(new EmptyBorder(5, 5, 5, 5));
|
messageEnterTextfield.setBorder(new EmptyBorder(5, 5, 5, 5));
|
||||||
|
|
||||||
GridBagConstraints gbc_moveSelectionMessageEnterTextfield = new GridBagConstraints();
|
GridBagConstraints gbc_moveSelectionMessageEnterTextfield = new GridBagConstraints();
|
||||||
gbc_moveSelectionMessageEnterTextfield.fill = GridBagConstraints.BOTH;
|
gbc_moveSelectionMessageEnterTextfield.fill = GridBagConstraints.BOTH;
|
||||||
gbc_moveSelectionMessageEnterTextfield.gridx = 1;
|
gbc_moveSelectionMessageEnterTextfield.gridx = 1;
|
||||||
gbc_moveSelectionMessageEnterTextfield.gridy = 2;
|
gbc_moveSelectionMessageEnterTextfield.gridy = 2;
|
||||||
|
|
||||||
gbc_moveSelectionMessageEnterTextfield.insets = new Insets(10, 10, 10, 10);
|
gbc_moveSelectionMessageEnterTextfield.insets = new Insets(10, 10, 10, 10);
|
||||||
|
|
||||||
contentPane.add(messageEnterTextfield, gbc_moveSelectionMessageEnterTextfield);
|
contentPane.add(messageEnterTextfield, gbc_moveSelectionMessageEnterTextfield);
|
||||||
|
|
||||||
|
// Post Button
|
||||||
|
|
||||||
|
|
||||||
// Post Button-----------------
|
|
||||||
JButton postButton = new JButton("Post");
|
JButton postButton = new JButton("Post");
|
||||||
postButton.setForeground(new Color(255, 255, 255));
|
postButton.setForeground(new Color(255, 255, 255));
|
||||||
postButton.setBackground(new Color(102, 51, 153));
|
postButton.setBackground(new Color(102, 51, 153));
|
||||||
@ -144,19 +110,19 @@ public class ChatWindow extends JFrame {
|
|||||||
|
|
||||||
GridBagConstraints gbc_moveSelectionPostButton = new GridBagConstraints();
|
GridBagConstraints gbc_moveSelectionPostButton = new GridBagConstraints();
|
||||||
|
|
||||||
gbc_moveSelectionPostButton.fill = GridBagConstraints.BOTH;
|
gbc_moveSelectionPostButton.fill = GridBagConstraints.BOTH;
|
||||||
gbc_moveSelectionPostButton.gridx = 2;
|
gbc_moveSelectionPostButton.gridx = 2;
|
||||||
gbc_moveSelectionPostButton.gridy = 2;
|
gbc_moveSelectionPostButton.gridy = 2;
|
||||||
|
|
||||||
gbc_moveSelectionPostButton.insets = new Insets(10, 10, 10, 10);
|
gbc_moveSelectionPostButton.insets = new Insets(10, 10, 10, 10);
|
||||||
|
|
||||||
|
|
||||||
contentPane.add(postButton, gbc_moveSelectionPostButton);
|
contentPane.add(postButton, gbc_moveSelectionPostButton);
|
||||||
|
|
||||||
postButton.addActionListener((evt) -> {
|
postButton.addActionListener((evt) -> {
|
||||||
if (!messageEnterTextfield.getText().isEmpty()) try {
|
if (!messageEnterTextfield.getText().isEmpty()) try {
|
||||||
envoyClient.sendMessage(envoyClient.createMessage("Kai", "Maxi", messageEnterTextfield.getText()));
|
final Message message = envoyClient.createMessage("Kai", "Maxi", messageEnterTextfield.getText());
|
||||||
addMessageToChat("Du", messageEnterTextfield.getText());
|
envoyClient.sendMessage(message);
|
||||||
|
appendMessageToChat(message);
|
||||||
messageEnterTextfield.setText("");
|
messageEnterTextfield.setText("");
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
JOptionPane.showMessageDialog(this,
|
JOptionPane.showMessageDialog(this,
|
||||||
@ -169,33 +135,26 @@ public class ChatWindow extends JFrame {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* gets the Sender from the Message
|
* Extracts the first text content from a message.
|
||||||
* @param message
|
*
|
||||||
* @return
|
* @param message The message from which to return the text content
|
||||||
|
* @return The first content of type 'text'
|
||||||
*/
|
*/
|
||||||
public String getSenderElement (Message message) {
|
public String getFirstTextContent(Message message) {
|
||||||
return message.getMetaData().getSender();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* gets the First Content Element(text) from the Message
|
|
||||||
* @param message
|
|
||||||
* @return
|
|
||||||
*/
|
|
||||||
public String getFirstContentElement (Message message) {
|
|
||||||
return message.getContent().get(0).getText();
|
return message.getContent().get(0).getText();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* adds the Sender and the First Content Element(text) of the new Message to the listModel
|
* Appends a message with sender and message content to the message list.
|
||||||
* @param message
|
*
|
||||||
* @return
|
* @param message The message to append
|
||||||
*/
|
*/
|
||||||
public void addMessageToChat(String Sender, String Content) {
|
private void appendMessageToChat(Message message) {
|
||||||
listModel.addElement("<html>" + "<p style=\"color:#d2d235\"> <b> <small>" + Sender + "</b> </small>" + "<br>" + "<p style=\"color:white\">" + Content + "</span></html>");
|
listModel.addElement("<html>" + "<p style=\"color:#d2d235\"> <b> <small>" + message.getMetaData().getSender()
|
||||||
|
+ "</b> </small>" + "<br>" + "<p style=\"color:white\">" + getFirstTextContent(message)
|
||||||
|
+ "</span></html>");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
public static void main(String[] args) {
|
public static void main(String[] args) {
|
||||||
EventQueue.invokeLater(() -> {
|
EventQueue.invokeLater(() -> {
|
||||||
try {
|
try {
|
||||||
|
Reference in New Issue
Block a user