forked from fanruan/design
ju
7 years ago
2 changed files with 0 additions and 94 deletions
@ -1,92 +0,0 @@
|
||||
package com.fr.design.mainframe.loghandler.socketio; |
||||
|
||||
import com.fr.design.mainframe.loghandler.DesignerLogHandler; |
||||
import com.fr.event.Event; |
||||
import com.fr.event.EventDispatcher; |
||||
import com.fr.event.Listener; |
||||
import com.fr.general.LogRecordTime; |
||||
import com.fr.general.LogUtils; |
||||
import com.fr.log.FineLoggerFactory; |
||||
import com.fr.third.guava.base.Optional; |
||||
import com.fr.workspace.WorkContext; |
||||
import com.fr.workspace.Workspace; |
||||
import com.fr.workspace.WorkspaceEvent; |
||||
import io.socket.client.Socket; |
||||
import io.socket.emitter.Emitter; |
||||
|
||||
import java.io.ByteArrayInputStream; |
||||
|
||||
public class DesignerSocketIO { |
||||
|
||||
private static Optional<Socket> socketIO = Optional.absent(); |
||||
|
||||
private static final Emitter.Listener printLog = new Emitter.Listener() { |
||||
@Override |
||||
public void call(Object... objects) { |
||||
try { |
||||
LogRecordTime[] logRecordTimes = LogUtils.readXMLLogRecords(new ByteArrayInputStream((byte[]) objects[0])); |
||||
for (LogRecordTime logRecordTime : logRecordTimes) { |
||||
DesignerLogHandler.getInstance().printRemoteLog(logRecordTime); |
||||
} |
||||
} catch (Exception e) { |
||||
FineLoggerFactory.getLogger().error(e.getMessage(), e); |
||||
} |
||||
} |
||||
}; |
||||
|
||||
static { |
||||
EventDispatcher.listen(WorkspaceEvent.BeforeSwitch, new Listener<Workspace>() { |
||||
@Override |
||||
public void on(Event event, Workspace param) { |
||||
if (socketIO.isPresent()) { |
||||
socketIO.get().close(); |
||||
socketIO = Optional.absent(); |
||||
} |
||||
} |
||||
}); |
||||
EventDispatcher.listen(WorkspaceEvent.AfterSwitch, new Listener<Workspace>() { |
||||
@Override |
||||
public void on(Event event, Workspace param) { |
||||
updateSocket(); |
||||
} |
||||
}); |
||||
} |
||||
|
||||
public static void init() { |
||||
updateSocket(); |
||||
} |
||||
|
||||
private static void updateSocket() { |
||||
|
||||
if (WorkContext.getCurrent().isLocal()) { |
||||
return; |
||||
} |
||||
try { |
||||
// RemoteEnvConfig config = ((RemoteEnv)env).getEnvConfig();
|
||||
// String uri = String.format("http://%s:%s%s?%s=%s",
|
||||
// config.getHost(),
|
||||
// WebSocketConfig.getInstance().getPort(),
|
||||
// EnvConstants.WS_NAMESPACE,
|
||||
// DecisionServiceConstants.WEB_SOCKET_TOKEN_NAME,
|
||||
// EnvContext.currentToken());
|
||||
//
|
||||
// socketIO = Optional.of(IO.socket(new URI(uri)));
|
||||
// socketIO.get().on(EnvConstants.WS_LOGRECORD, printLog);
|
||||
// socketIO.get().on(EnvConstants.CONFIG, new Emitter.Listener() {
|
||||
// @Override
|
||||
// public void call(Object... objects) {
|
||||
// if (objects == null || objects.length != 1) {
|
||||
// throw new IllegalArgumentException("config should have only one param");
|
||||
// }
|
||||
// Object param = objects[0];
|
||||
// if (param instanceof Class) {
|
||||
// EventDispatcher.fire(ConfigEvent.EDIT, (Class<? extends Configuration>) param);
|
||||
// }
|
||||
// }
|
||||
// });
|
||||
// socketIO.get().connect();
|
||||
} catch (Exception e) { |
||||
FineLoggerFactory.getLogger().error(e.getMessage(), e); |
||||
} |
||||
} |
||||
} |
Loading…
Reference in new issue