mirror of
https://github.com/Akomry/sae302_applicom.git
synced 2025-12-06 08:43:54 +00:00
feat(Event): 2.6.5: Récupération des posts après changement de discussion
This commit is contained in:
parent
48da92717b
commit
1732a63a4a
3 changed files with 44 additions and 12 deletions
|
|
@ -278,6 +278,7 @@ public class ChatController implements Initializable {
|
|||
Post postSys = new Post("system", loginTextField.getText(), "Bienvenue dans la discussion avec " + contactSelected.getLogin());
|
||||
postsObservableList.clear();
|
||||
postsObservableList.add(postSys);
|
||||
client.sendListPostEvent(0, contactSelected.getLogin());
|
||||
postListView.refresh();
|
||||
}
|
||||
|
||||
|
|
|
|||
|
|
@ -58,6 +58,16 @@ public class ChatClient extends ClientTCP {
|
|||
sendEvent(authEvent);
|
||||
}
|
||||
|
||||
public void sendListPostEvent(long since, String select) {
|
||||
Event listPostEvent = new Event(
|
||||
Event.LIST_POSTS,
|
||||
new JSONObject()
|
||||
.put("since", since)
|
||||
.put("select", select)
|
||||
);
|
||||
sendEvent(listPostEvent);
|
||||
}
|
||||
|
||||
|
||||
@Override
|
||||
public void receiveLoop() {
|
||||
|
|
|
|||
|
|
@ -250,27 +250,48 @@ public class ChatServer {
|
|||
doMessage(event.getContent());
|
||||
LOGGER.info("Receiving message");
|
||||
return true;
|
||||
} else if (event.getType().equals(Event.LIST_POSTS)) {
|
||||
doListPost(event.getContent());
|
||||
LOGGER.info("Sending Posts");
|
||||
return true;
|
||||
} else {
|
||||
LOGGER.warning("Unhandled event type: " + event.getType());
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
private void doListPost(JSONObject content) throws JSONException, IllegalStateException {
|
||||
|
||||
if (contactMap.getContact(user.getLogin()).isConnected()) {
|
||||
if (!contactMap.containsKey(content.getString("select"))) {
|
||||
throw new IllegalStateException();
|
||||
}
|
||||
for (Post post: postVector.getPostsSince(content.getLong("since"))) {
|
||||
if (post.getTo().equals(content.getString("select")) ||
|
||||
post.getFrom().equals(content.getString("select"))) {
|
||||
sendEventToContact(contactMap.getContact(user.getLogin()), new Event(Event.POST, post.toJsonObject()));
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private void doMessage(JSONObject content) throws JSONException, IllegalStateException {
|
||||
if (content.getString("to").equals(user.getLogin()) || !contactMap.containsKey(content.getString("to"))) {
|
||||
throw new IllegalStateException();
|
||||
} else {
|
||||
Post post = new Post(
|
||||
user.getLogin(),
|
||||
Message.fromJson(content)
|
||||
);
|
||||
Event postEvent = new Event("POST", post.toJsonObject());
|
||||
if (contactMap.getContact(user.getLogin()).isConnected()) {
|
||||
if (content.getString("to").equals(user.getLogin()) || !contactMap.containsKey(content.getString("to"))) {
|
||||
throw new IllegalStateException();
|
||||
} else {
|
||||
Post post = new Post(
|
||||
user.getLogin(),
|
||||
Message.fromJson(content)
|
||||
);
|
||||
Event postEvent = new Event("POST", post.toJsonObject());
|
||||
|
||||
sendEventToContact(contactMap.getContact(post.getFrom()), postEvent);
|
||||
sendEventToContact(contactMap.getContact(post.getTo()), postEvent);
|
||||
sendEventToContact(contactMap.getContact(post.getFrom()), postEvent);
|
||||
sendEventToContact(contactMap.getContact(post.getTo()), postEvent);
|
||||
|
||||
postVector.add(post);
|
||||
LOGGER.info("Fin de doMessage");
|
||||
postVector.add(post);
|
||||
LOGGER.info("Fin de doMessage");
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue