IDEMPIERE-4451 Executions.schedule should be executed asynchronously (#266)
onpiggyback should check whether's there's pending serverpush echo
This commit is contained in:
parent
4c1ba12a3f
commit
98ab98b28c
|
@ -48,6 +48,8 @@ import org.zkoss.zk.ui.util.Clients;
|
||||||
*/
|
*/
|
||||||
public class AtmosphereServerPush implements ServerPush {
|
public class AtmosphereServerPush implements ServerPush {
|
||||||
|
|
||||||
|
private static final String ATMOSPHERE_SERVER_PUSH_ECHO = "AtmosphereServerPush.Echo";
|
||||||
|
|
||||||
private static final String ON_ACTIVATE_DESKTOP = "onActivateDesktop";
|
private static final String ON_ACTIVATE_DESKTOP = "onActivateDesktop";
|
||||||
|
|
||||||
public static final int DEFAULT_TIMEOUT = 1000 * 60 * 2;
|
public static final int DEFAULT_TIMEOUT = 1000 * 60 * 2;
|
||||||
|
@ -162,6 +164,11 @@ public class AtmosphereServerPush implements ServerPush {
|
||||||
@SuppressWarnings("unchecked")
|
@SuppressWarnings("unchecked")
|
||||||
@Override
|
@Override
|
||||||
public void onPiggyback() {
|
public void onPiggyback() {
|
||||||
|
if (Executions.getCurrent() != null && Executions.getCurrent().getAttribute(ATMOSPHERE_SERVER_PUSH_ECHO) != null) {
|
||||||
|
//has pending serverpush echo, wait for next execution piggyback trigger by the pending serverpush echo
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
Schedule<Event>[] pendings = null;
|
Schedule<Event>[] pendings = null;
|
||||||
synchronized (schedules) {
|
synchronized (schedules) {
|
||||||
if (!schedules.isEmpty()) {
|
if (!schedules.isEmpty()) {
|
||||||
|
@ -195,8 +202,8 @@ public class AtmosphereServerPush implements ServerPush {
|
||||||
synchronized (schedules) {
|
synchronized (schedules) {
|
||||||
schedules.add(new Schedule(task, event, scheduler));
|
schedules.add(new Schedule(task, event, scheduler));
|
||||||
}
|
}
|
||||||
if (Executions.getCurrent().getAttribute("AtmosphereServerPush.Echo") == null) {
|
if (Executions.getCurrent().getAttribute(ATMOSPHERE_SERVER_PUSH_ECHO) == null) {
|
||||||
Executions.getCurrent().setAttribute("AtmosphereServerPush.Echo", Boolean.TRUE);
|
Executions.getCurrent().setAttribute(ATMOSPHERE_SERVER_PUSH_ECHO, Boolean.TRUE);
|
||||||
Clients.response(new AuEcho());
|
Clients.response(new AuEcho());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -52,6 +52,8 @@ import org.zkoss.zk.ui.util.Clients;
|
||||||
*/
|
*/
|
||||||
public class WebSocketServerPush implements ServerPush {
|
public class WebSocketServerPush implements ServerPush {
|
||||||
|
|
||||||
|
private static final String ATMOSPHERE_SERVER_PUSH_ECHO = "AtmosphereServerPush.Echo";
|
||||||
|
|
||||||
private static final String ON_ACTIVATE_DESKTOP = "onActivateDesktop";
|
private static final String ON_ACTIVATE_DESKTOP = "onActivateDesktop";
|
||||||
|
|
||||||
private final AtomicReference<Desktop> desktop = new AtomicReference<Desktop>();
|
private final AtomicReference<Desktop> desktop = new AtomicReference<Desktop>();
|
||||||
|
@ -168,6 +170,11 @@ public class WebSocketServerPush implements ServerPush {
|
||||||
@SuppressWarnings("unchecked")
|
@SuppressWarnings("unchecked")
|
||||||
@Override
|
@Override
|
||||||
public void onPiggyback() {
|
public void onPiggyback() {
|
||||||
|
if (Executions.getCurrent() != null && Executions.getCurrent().getAttribute(ATMOSPHERE_SERVER_PUSH_ECHO) != null) {
|
||||||
|
//has pending serverpush echo, wait for next execution piggyback trigger by the pending serverpush echo
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
Schedule<Event>[] pendings = null;
|
Schedule<Event>[] pendings = null;
|
||||||
synchronized (schedules) {
|
synchronized (schedules) {
|
||||||
if (!schedules.isEmpty()) {
|
if (!schedules.isEmpty()) {
|
||||||
|
@ -208,8 +215,8 @@ public class WebSocketServerPush implements ServerPush {
|
||||||
synchronized (schedules) {
|
synchronized (schedules) {
|
||||||
schedules.add(new Schedule(task, event, scheduler));
|
schedules.add(new Schedule(task, event, scheduler));
|
||||||
}
|
}
|
||||||
if (Executions.getCurrent().getAttribute("AtmosphereServerPush.Echo") == null) {
|
if (Executions.getCurrent().getAttribute(ATMOSPHERE_SERVER_PUSH_ECHO) == null) {
|
||||||
Executions.getCurrent().setAttribute("AtmosphereServerPush.Echo", Boolean.TRUE);
|
Executions.getCurrent().setAttribute(ATMOSPHERE_SERVER_PUSH_ECHO, Boolean.TRUE);
|
||||||
Clients.response(new AuEcho());
|
Clients.response(new AuEcho());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue