ing
This commit is contained in:
parent
963ac0c068
commit
3f9d6c05c2
|
@ -6,10 +6,10 @@ import io.grpc.Metadata;
|
||||||
import static io.grpc.Metadata.ASCII_STRING_MARSHALLER;
|
import static io.grpc.Metadata.ASCII_STRING_MARSHALLER;
|
||||||
|
|
||||||
public class SessionMetadata {
|
public class SessionMetadata {
|
||||||
public static final Context.Key<String> CTX_EMAIL_KEY = Context.key("email");
|
public static final Context.Key<String> CTX_SESSION_ID_KEY = Context.key("SESSION_ID");
|
||||||
public static final Metadata.Key<String> METADATA_EMAIL_KEY = Metadata.Key.of("email", ASCII_STRING_MARSHALLER);
|
public static final Metadata.Key<String> METADATA_SESSION_ID_KEY = Metadata.Key.of("SESSION_ID", ASCII_STRING_MARSHALLER);
|
||||||
|
|
||||||
public static String getEmail() {
|
public static String getSessionID() {
|
||||||
return CTX_EMAIL_KEY.get();
|
return CTX_SESSION_ID_KEY.get();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,11 @@
|
||||||
|
package com.loafle.overflow.commons.stereotype;
|
||||||
|
|
||||||
|
import java.lang.annotation.ElementType;
|
||||||
|
import java.lang.annotation.Retention;
|
||||||
|
import java.lang.annotation.RetentionPolicy;
|
||||||
|
import java.lang.annotation.Target;
|
||||||
|
|
||||||
|
@Target({ElementType.METHOD})
|
||||||
|
@Retention(RetentionPolicy.RUNTIME)
|
||||||
|
public @interface ProbeAPI {
|
||||||
|
}
|
|
@ -0,0 +1,11 @@
|
||||||
|
package com.loafle.overflow.commons.stereotype;
|
||||||
|
|
||||||
|
import java.lang.annotation.ElementType;
|
||||||
|
import java.lang.annotation.Retention;
|
||||||
|
import java.lang.annotation.RetentionPolicy;
|
||||||
|
import java.lang.annotation.Target;
|
||||||
|
|
||||||
|
@Target({ElementType.METHOD})
|
||||||
|
@Retention(RetentionPolicy.RUNTIME)
|
||||||
|
public @interface WebappAPI {
|
||||||
|
}
|
|
@ -0,0 +1,52 @@
|
||||||
|
package com.loafle.overflow.module.discovery.model;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
public class DiscoveryHost {
|
||||||
|
private String firstScanRange;
|
||||||
|
private String lastScanRange;
|
||||||
|
private List<String> excludeHosts;
|
||||||
|
private List<String> includeHosts;
|
||||||
|
|
||||||
|
private DiscoveryPort discoveryPort;
|
||||||
|
|
||||||
|
public String getFirstScanRange() {
|
||||||
|
return firstScanRange;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setFirstScanRange(String firstScanRange) {
|
||||||
|
this.firstScanRange = firstScanRange;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getLastScanRange() {
|
||||||
|
return lastScanRange;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setLastScanRange(String lastScanRange) {
|
||||||
|
this.lastScanRange = lastScanRange;
|
||||||
|
}
|
||||||
|
|
||||||
|
public List<String> getExcludeHosts() {
|
||||||
|
return excludeHosts;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setExcludeHosts(List<String> excludeHosts) {
|
||||||
|
this.excludeHosts = excludeHosts;
|
||||||
|
}
|
||||||
|
|
||||||
|
public List<String> getIncludeHosts() {
|
||||||
|
return includeHosts;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setIncludeHosts(List<String> includeHosts) {
|
||||||
|
this.includeHosts = includeHosts;
|
||||||
|
}
|
||||||
|
|
||||||
|
public DiscoveryPort getDiscoveryPort() {
|
||||||
|
return discoveryPort;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setDiscoveryPort(DiscoveryPort discoveryPort) {
|
||||||
|
this.discoveryPort = discoveryPort;
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,61 @@
|
||||||
|
package com.loafle.overflow.module.discovery.model;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
public class DiscoveryPort {
|
||||||
|
private int firstScanRange;
|
||||||
|
private int lastScanRange;
|
||||||
|
private List<Integer> excludePorts;
|
||||||
|
private boolean includeTCP;
|
||||||
|
private boolean includeUDP;
|
||||||
|
|
||||||
|
private DiscoveryService discoveryService;
|
||||||
|
|
||||||
|
public int getFirstScanRange() {
|
||||||
|
return firstScanRange;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setFirstScanRange(int firstScanRange) {
|
||||||
|
this.firstScanRange = firstScanRange;
|
||||||
|
}
|
||||||
|
|
||||||
|
public int getLastScanRange() {
|
||||||
|
return lastScanRange;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setLastScanRange(int lastScanRange) {
|
||||||
|
this.lastScanRange = lastScanRange;
|
||||||
|
}
|
||||||
|
|
||||||
|
public List<Integer> getExcludePorts() {
|
||||||
|
return excludePorts;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setExcludePorts(List<Integer> excludePorts) {
|
||||||
|
this.excludePorts = excludePorts;
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean isIncludeTCP() {
|
||||||
|
return includeTCP;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setIncludeTCP(boolean includeTCP) {
|
||||||
|
this.includeTCP = includeTCP;
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean isIncludeUDP() {
|
||||||
|
return includeUDP;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setIncludeUDP(boolean includeUDP) {
|
||||||
|
this.includeUDP = includeUDP;
|
||||||
|
}
|
||||||
|
|
||||||
|
public DiscoveryService getDiscoveryService() {
|
||||||
|
return discoveryService;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setDiscoveryService(DiscoveryService discoveryService) {
|
||||||
|
this.discoveryService = discoveryService;
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,15 @@
|
||||||
|
package com.loafle.overflow.module.discovery.model;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
public class DiscoveryService {
|
||||||
|
private List<String> includeServices;
|
||||||
|
|
||||||
|
public List<String> getIncludeServices() {
|
||||||
|
return includeServices;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setIncludeServices(List<String> includeServices) {
|
||||||
|
this.includeServices = includeServices;
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,25 @@
|
||||||
|
package com.loafle.overflow.module.discovery.model;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
public class DiscoveryZone {
|
||||||
|
private List<String> excludePatterns;
|
||||||
|
|
||||||
|
private DiscoveryHost discoveryHost;
|
||||||
|
|
||||||
|
public List<String> getExcludePatterns() {
|
||||||
|
return excludePatterns;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setExcludePatterns(List<String> excludePatterns) {
|
||||||
|
this.excludePatterns = excludePatterns;
|
||||||
|
}
|
||||||
|
|
||||||
|
public DiscoveryHost getDiscoveryHost() {
|
||||||
|
return discoveryHost;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setDiscoveryHost(DiscoveryHost discoveryHost) {
|
||||||
|
this.discoveryHost = discoveryHost;
|
||||||
|
}
|
||||||
|
}
|
|
@ -1,39 +1,19 @@
|
||||||
package com.loafle.overflow.module.discovery.model;
|
package com.loafle.overflow.module.discovery.model;
|
||||||
|
|
||||||
|
|
||||||
import java.util.Date;
|
import java.util.Date;
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Created by root on 17. 6. 4.
|
* Created by root on 17. 6. 4.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
public class Host {
|
public class Host {
|
||||||
|
|
||||||
|
|
||||||
private long id;
|
private long id;
|
||||||
private long ip;
|
private long ip;
|
||||||
private long mac;
|
private long mac;
|
||||||
|
|
||||||
private Date createDate;
|
|
||||||
private Date updateDate;
|
|
||||||
|
|
||||||
private String os;
|
private String os;
|
||||||
private boolean target;
|
private Date discoveredDate;
|
||||||
|
|
||||||
|
|
||||||
private List<Port> ports;
|
|
||||||
|
|
||||||
public List<Port> getPorts() {
|
|
||||||
return ports;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setPorts(List<Port> ports) {
|
|
||||||
this.ports = ports;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
private Zone zone;
|
||||||
|
|
||||||
public Host(){}
|
public Host(){}
|
||||||
|
|
||||||
|
@ -66,22 +46,6 @@ public class Host {
|
||||||
this.mac = mac;
|
this.mac = mac;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Date getCreateDate() {
|
|
||||||
return createDate;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setCreateDate(Date createDate) {
|
|
||||||
this.createDate = createDate;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Date getUpdateDate() {
|
|
||||||
return updateDate;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setUpdateDate(Date updateDate) {
|
|
||||||
this.updateDate = updateDate;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getOs() {
|
public String getOs() {
|
||||||
return os;
|
return os;
|
||||||
}
|
}
|
||||||
|
@ -90,11 +54,19 @@ public class Host {
|
||||||
this.os = os;
|
this.os = os;
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean isTarget() {
|
public Date getDiscoveredDate() {
|
||||||
return target;
|
return discoveredDate;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setTarget(boolean target) {
|
public void setDiscoveredDate(Date discoveredDate) {
|
||||||
this.target = target;
|
this.discoveredDate = discoveredDate;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Zone getZone() {
|
||||||
|
return zone;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setZone(Zone zone) {
|
||||||
|
this.zone = zone;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -8,7 +8,6 @@ package com.loafle.overflow.module.discovery.model;
|
||||||
import com.loafle.overflow.module.discovery.type.PortType;
|
import com.loafle.overflow.module.discovery.type.PortType;
|
||||||
|
|
||||||
import java.util.Date;
|
import java.util.Date;
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Created by root on 17. 6. 4.
|
* Created by root on 17. 6. 4.
|
||||||
|
@ -18,54 +17,14 @@ public class Port {
|
||||||
|
|
||||||
|
|
||||||
private long id;
|
private long id;
|
||||||
|
private PortType portType;
|
||||||
|
private int portNumber;
|
||||||
|
private Date discoveredDate;
|
||||||
|
|
||||||
private Host host;
|
private Host host;
|
||||||
public Host getHost() {
|
|
||||||
return host;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setHost(Host host) {
|
|
||||||
this.host = host;
|
|
||||||
}
|
|
||||||
|
|
||||||
private PortType portType;
|
|
||||||
|
|
||||||
|
|
||||||
private int portNumber;
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
private List<Service> services;
|
|
||||||
|
|
||||||
public List<Service> getServices() {
|
|
||||||
return services;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setServices(List<Service> services) {
|
|
||||||
this.services = services;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
private Date createDate;
|
|
||||||
|
|
||||||
|
|
||||||
private Date updateDate;
|
|
||||||
|
|
||||||
public Port() {}
|
public Port() {}
|
||||||
|
|
||||||
public Port(PortType type, int portNumber) {
|
|
||||||
this.portType = type;
|
|
||||||
this.portNumber = portNumber;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Port(Host host, PortType type, int portNumber) {
|
|
||||||
this.host = host;
|
|
||||||
this.portType = type;
|
|
||||||
this.portNumber = portNumber;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
public long getId() {
|
public long getId() {
|
||||||
return id;
|
return id;
|
||||||
}
|
}
|
||||||
|
@ -90,33 +49,20 @@ public class Port {
|
||||||
this.portNumber = portNumber;
|
this.portNumber = portNumber;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public Date getDiscoveredDate() {
|
||||||
|
return discoveredDate;
|
||||||
public Date getCreateDate() {
|
|
||||||
return createDate;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setCreateDate(Date createDate) {
|
public void setDiscoveredDate(Date discoveredDate) {
|
||||||
this.createDate = createDate;
|
this.discoveredDate = discoveredDate;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Date getUpdateDate() {
|
public Host getHost() {
|
||||||
return updateDate;
|
return host;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setUpdateDate(Date updateDate) {
|
public void setHost(Host host) {
|
||||||
this.updateDate = updateDate;
|
this.host = host;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void mappingChildren(Host discoveryHost) {
|
|
||||||
this.setHost(discoveryHost);
|
|
||||||
|
|
||||||
|
|
||||||
List<Service> discoveryServices = this.getServices();
|
|
||||||
if (discoveryServices != null) {
|
|
||||||
for (int z = 0 ; z < discoveryServices.size() ; ++z) {
|
|
||||||
discoveryServices.get(z).setPort(this);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,8 +1,5 @@
|
||||||
package com.loafle.overflow.module.discovery.model;
|
package com.loafle.overflow.module.discovery.model;
|
||||||
|
|
||||||
|
|
||||||
import com.loafle.overflow.module.discovery.type.PortType;
|
|
||||||
|
|
||||||
import java.util.Date;
|
import java.util.Date;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -10,48 +7,29 @@ import java.util.Date;
|
||||||
*/
|
*/
|
||||||
|
|
||||||
public class Service {
|
public class Service {
|
||||||
|
|
||||||
|
|
||||||
private long id;
|
private long id;
|
||||||
|
private String cryptoType;
|
||||||
|
private String serviceName;
|
||||||
|
private Date discoveredDate;
|
||||||
|
|
||||||
private Port port;
|
private Port port;
|
||||||
public Port getPort() {
|
|
||||||
return port;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setPort(Port port) {
|
|
||||||
this.port = port;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
private PortType portType;
|
|
||||||
|
|
||||||
|
|
||||||
private String serviceName;
|
|
||||||
|
|
||||||
|
|
||||||
private Date createDate;
|
|
||||||
|
|
||||||
|
|
||||||
private Date updateDate;
|
|
||||||
|
|
||||||
private boolean target;
|
|
||||||
|
|
||||||
public Service() {}
|
public Service() {}
|
||||||
|
|
||||||
public Service(Port port, PortType t, String serviceName) {
|
public long getId() {
|
||||||
this.port = port;
|
return id;
|
||||||
this.portType = t;
|
|
||||||
this.serviceName = serviceName;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public PortType getPortType() {
|
public void setId(long id) {
|
||||||
return portType;
|
this.id = id;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setPortType(PortType portType) {
|
public String getCryptoType() {
|
||||||
this.portType = portType;
|
return cryptoType;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setCryptoType(String cryptoType) {
|
||||||
|
this.cryptoType = cryptoType;
|
||||||
}
|
}
|
||||||
|
|
||||||
public String getServiceName() {
|
public String getServiceName() {
|
||||||
|
@ -62,36 +40,21 @@ public class Service {
|
||||||
this.serviceName = serviceName;
|
this.serviceName = serviceName;
|
||||||
}
|
}
|
||||||
|
|
||||||
public long getId() {
|
public Date getDiscoveredDate() {
|
||||||
return id;
|
return discoveredDate;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setId(long id) {
|
public void setDiscoveredDate(Date discoveredDate) {
|
||||||
this.id = id;
|
this.discoveredDate = discoveredDate;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Port getPort() {
|
||||||
|
return port;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setPort(Port port) {
|
||||||
|
this.port = port;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
public Date getCreateDate() {
|
|
||||||
return createDate;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setCreateDate(Date createDate) {
|
|
||||||
this.createDate = createDate;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Date getUpdateDate() {
|
|
||||||
return updateDate;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setUpdateDate(Date updateDate) {
|
|
||||||
this.updateDate = updateDate;
|
|
||||||
}
|
|
||||||
|
|
||||||
public boolean isTarget() {
|
|
||||||
return target;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setTarget(boolean target) {
|
|
||||||
this.target = target;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,5 +1,7 @@
|
||||||
package com.loafle.overflow.module.discovery.model;
|
package com.loafle.overflow.module.discovery.model;
|
||||||
|
|
||||||
|
import java.util.Date;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Created by snoop on 17. 10. 31.
|
* Created by snoop on 17. 10. 31.
|
||||||
*/
|
*/
|
||||||
|
@ -9,8 +11,7 @@ public class Zone {
|
||||||
private String ip;
|
private String ip;
|
||||||
private String iface;
|
private String iface;
|
||||||
private String mac;
|
private String mac;
|
||||||
private long firstScanRange;
|
private Date discoveredDate;
|
||||||
private long lastScanRange;
|
|
||||||
|
|
||||||
public long getId() {
|
public long getId() {
|
||||||
return id;
|
return id;
|
||||||
|
@ -52,19 +53,11 @@ public class Zone {
|
||||||
this.mac = mac;
|
this.mac = mac;
|
||||||
}
|
}
|
||||||
|
|
||||||
public long getFirstScanRange() {
|
public Date getDiscoveredDate() {
|
||||||
return firstScanRange;
|
return discoveredDate;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setFirstScanRange(long firstScanRange) {
|
public void setDiscoveredDate(Date discoveredDate) {
|
||||||
this.firstScanRange = firstScanRange;
|
this.discoveredDate = discoveredDate;
|
||||||
}
|
|
||||||
|
|
||||||
public long getLastScanRange() {
|
|
||||||
return lastScanRange;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setLastScanRange(long lastScanRange) {
|
|
||||||
this.lastScanRange = lastScanRange;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,7 +1,16 @@
|
||||||
package com.loafle.overflow.module.discovery.service;
|
package com.loafle.overflow.module.discovery.service;
|
||||||
|
|
||||||
|
import com.loafle.overflow.commons.model.SessionMetadata;
|
||||||
import com.loafle.overflow.commons.service.MessagePublisher;
|
import com.loafle.overflow.commons.service.MessagePublisher;
|
||||||
|
import com.loafle.overflow.commons.stereotype.ProbeAPI;
|
||||||
|
import com.loafle.overflow.commons.stereotype.WebappAPI;
|
||||||
|
import com.loafle.overflow.module.discovery.model.DiscoveryHost;
|
||||||
|
import com.loafle.overflow.module.discovery.model.DiscoveryPort;
|
||||||
import com.loafle.overflow.module.discovery.model.DiscoveryStartInfo;
|
import com.loafle.overflow.module.discovery.model.DiscoveryStartInfo;
|
||||||
|
import com.loafle.overflow.module.discovery.model.DiscoveryZone;
|
||||||
|
import com.loafle.overflow.module.discovery.model.Host;
|
||||||
|
import com.loafle.overflow.module.discovery.model.Port;
|
||||||
|
import com.loafle.overflow.module.discovery.model.Zone;
|
||||||
import com.loafle.overflow.module.domain.model.Domain;
|
import com.loafle.overflow.module.domain.model.Domain;
|
||||||
import org.codehaus.jackson.map.ObjectMapper;
|
import org.codehaus.jackson.map.ObjectMapper;
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
@ -49,5 +58,55 @@ public class DiscoveryService {
|
||||||
|
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@WebappAPI
|
||||||
|
public void discoverZone(String probeID, DiscoveryZone discoveryZone) {
|
||||||
|
String requestMemberEmail = SessionMetadata.getSessionID();
|
||||||
|
|
||||||
|
messagePublisher.publishToProbe("/probe", probeID, "DiscoveryService.DiscoverZone", requestMemberEmail, discoveryZone);
|
||||||
|
}
|
||||||
|
|
||||||
|
@WebappAPI
|
||||||
|
public void discoverHost(String probeID, Zone zone, DiscoveryHost discoveryHost) {
|
||||||
|
String requestMemberEmail = SessionMetadata.getSessionID();
|
||||||
|
|
||||||
|
messagePublisher.publishToProbe("/probe", probeID, "DiscoveryService.DiscoverHost", requestMemberEmail, zone, discoveryHost);
|
||||||
|
}
|
||||||
|
|
||||||
|
@WebappAPI
|
||||||
|
public void discoverPort(String probeID, Host host, DiscoveryPort discoveryPort) {
|
||||||
|
String requestMemberEmail = SessionMetadata.getSessionID();
|
||||||
|
|
||||||
|
messagePublisher.publishToProbe("/probe", probeID, "DiscoveryService.DiscoverPort", requestMemberEmail, host, discoveryPort);
|
||||||
|
}
|
||||||
|
|
||||||
|
@WebappAPI
|
||||||
|
public void discoverService(String probeID, Port port, com.loafle.overflow.module.discovery.model.DiscoveryService discoveryService) {
|
||||||
|
String requestMemberEmail = SessionMetadata.getSessionID();
|
||||||
|
|
||||||
|
messagePublisher.publishToProbe("/probe", probeID, "DiscoveryService.DiscoverService", requestMemberEmail, port, discoveryService);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ProbeAPI
|
||||||
|
public void discoveredZone(String requestMemberEmail, Zone zone) {
|
||||||
|
messagePublisher.publishToMember("/webapp", requestMemberEmail, "DiscoveryService.discoveredZone", zone);
|
||||||
|
}
|
||||||
|
|
||||||
|
@ProbeAPI
|
||||||
|
public void discoveredHost(String requestMemberEmail, Host host) {
|
||||||
|
messagePublisher.publishToMember("/webapp", requestMemberEmail, "DiscoveryService.discoveredHost", host);
|
||||||
|
}
|
||||||
|
|
||||||
|
@ProbeAPI
|
||||||
|
public void discoveredPort(String requestMemberEmail, Port port) {
|
||||||
|
messagePublisher.publishToMember("/webapp", requestMemberEmail, "DiscoveryService.discoveredPort", port);
|
||||||
|
}
|
||||||
|
|
||||||
|
@ProbeAPI
|
||||||
|
public void discoveredService(String requestMemberEmail, com.loafle.overflow.module.discovery.model.Service service) {
|
||||||
|
messagePublisher.publishToMember("/webapp", requestMemberEmail, "DiscoveryService.discoveredService", service);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
|
@ -1,6 +1,7 @@
|
||||||
package com.loafle.overflow.module.member.service;
|
package com.loafle.overflow.module.member.service;
|
||||||
|
|
||||||
import com.loafle.overflow.commons.model.SessionMetadata;
|
import com.loafle.overflow.commons.model.SessionMetadata;
|
||||||
|
import com.loafle.overflow.commons.stereotype.WebappAPI;
|
||||||
import com.loafle.overflow.commons.utils.EmailSender;
|
import com.loafle.overflow.commons.utils.EmailSender;
|
||||||
import com.loafle.overflow.module.apikey.model.ApiKey;
|
import com.loafle.overflow.module.apikey.model.ApiKey;
|
||||||
import com.loafle.overflow.module.apikey.service.ApiKeyService;
|
import com.loafle.overflow.module.apikey.service.ApiKeyService;
|
||||||
|
@ -21,7 +22,6 @@ import org.springframework.stereotype.Service;
|
||||||
|
|
||||||
import java.io.UnsupportedEncodingException;
|
import java.io.UnsupportedEncodingException;
|
||||||
import java.net.URLDecoder;
|
import java.net.URLDecoder;
|
||||||
import java.net.URLEncoder;
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.regex.Matcher;
|
import java.util.regex.Matcher;
|
||||||
import java.util.regex.Pattern;
|
import java.util.regex.Pattern;
|
||||||
|
@ -113,7 +113,6 @@ public class MemberService {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
return resMember;
|
return resMember;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -161,8 +160,9 @@ public class MemberService {
|
||||||
// Todo websocket session remove
|
// Todo websocket session remove
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@WebappAPI
|
||||||
public Member modify(Member member, String pw) {
|
public Member modify(Member member, String pw) {
|
||||||
String email = SessionMetadata.getEmail();
|
String email = SessionMetadata.getSessionID();
|
||||||
Member preMember = this.memberDAO.findByEmail(member.getEmail());
|
Member preMember = this.memberDAO.findByEmail(member.getEmail());
|
||||||
|
|
||||||
if (null != pw && !pw.equals("")) {
|
if (null != pw && !pw.equals("")) {
|
||||||
|
@ -227,8 +227,9 @@ public class MemberService {
|
||||||
return resMember;
|
return resMember;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@WebappAPI
|
||||||
public void withdrawal(Member member) {
|
public void withdrawal(Member member) {
|
||||||
String email = SessionMetadata.getEmail();
|
String email = SessionMetadata.getSessionID();
|
||||||
|
|
||||||
// Todo DB delete?
|
// Todo DB delete?
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,6 +1,8 @@
|
||||||
package com.loafle.overflow.module.noauthprobe.service;
|
package com.loafle.overflow.module.noauthprobe.service;
|
||||||
|
|
||||||
import com.loafle.overflow.commons.service.MessagePublisher;
|
import com.loafle.overflow.commons.service.MessagePublisher;
|
||||||
|
import com.loafle.overflow.commons.stereotype.ProbeAPI;
|
||||||
|
import com.loafle.overflow.commons.stereotype.WebappAPI;
|
||||||
import com.loafle.overflow.module.apikey.model.ApiKey;
|
import com.loafle.overflow.module.apikey.model.ApiKey;
|
||||||
import com.loafle.overflow.module.apikey.service.ApiKeyService;
|
import com.loafle.overflow.module.apikey.service.ApiKeyService;
|
||||||
import com.loafle.overflow.module.domain.model.Domain;
|
import com.loafle.overflow.module.domain.model.Domain;
|
||||||
|
@ -44,6 +46,7 @@ public class NoAuthProbeService {
|
||||||
@Autowired
|
@Autowired
|
||||||
private MessagePublisher messagePublisher;
|
private MessagePublisher messagePublisher;
|
||||||
|
|
||||||
|
@ProbeAPI
|
||||||
public NoAuthProbe regist(NoAuthProbe noAuthProbe) {
|
public NoAuthProbe regist(NoAuthProbe noAuthProbe) {
|
||||||
|
|
||||||
noAuthProbe.setTempProbeKey(UUID.randomUUID().toString());
|
noAuthProbe.setTempProbeKey(UUID.randomUUID().toString());
|
||||||
|
@ -67,6 +70,7 @@ public class NoAuthProbeService {
|
||||||
return this.noAuthProbeDAO.findOne(id);
|
return this.noAuthProbeDAO.findOne(id);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@WebappAPI
|
||||||
public List<NoAuthProbe> acceptNoAuthProbe(NoAuthProbe noAuthProbe) throws IOException {
|
public List<NoAuthProbe> acceptNoAuthProbe(NoAuthProbe noAuthProbe) throws IOException {
|
||||||
|
|
||||||
// Todo domain injection & member injection
|
// Todo domain injection & member injection
|
||||||
|
@ -108,6 +112,7 @@ public class NoAuthProbeService {
|
||||||
return this.readAllByDomain(noAuthProbe.getDomain());
|
return this.readAllByDomain(noAuthProbe.getDomain());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@WebappAPI
|
||||||
public List<NoAuthProbe> denyNoauthProbe(NoAuthProbe noAuthProbe) {
|
public List<NoAuthProbe> denyNoauthProbe(NoAuthProbe noAuthProbe) {
|
||||||
this.noAuthProbeDAO.save(noAuthProbe);
|
this.noAuthProbeDAO.save(noAuthProbe);
|
||||||
|
|
||||||
|
|
|
@ -44,177 +44,177 @@ public class TargetDiscoveryService {
|
||||||
@Autowired
|
@Autowired
|
||||||
private InfraServiceService infraServiceService;
|
private InfraServiceService infraServiceService;
|
||||||
|
|
||||||
@Transactional
|
// @Transactional
|
||||||
public boolean saveAllTarget(List<Host> hosts, Probe probe) {
|
// public boolean saveAllTarget(List<Host> hosts, Probe probe) {
|
||||||
|
|
||||||
InfraHost infraHost = null;
|
// InfraHost infraHost = null;
|
||||||
|
|
||||||
for(Host host : hosts) {
|
// for(Host host : hosts) {
|
||||||
|
|
||||||
infraHost = this.createAndReadHost(host, probe);
|
// infraHost = this.createAndReadHost(host, probe);
|
||||||
|
|
||||||
this.createPort(infraHost, host, probe);
|
// this.createPort(infraHost, host, probe);
|
||||||
|
|
||||||
}
|
// }
|
||||||
return true;
|
// return true;
|
||||||
}
|
// }
|
||||||
|
|
||||||
private void createService(InfraHost infraHost, Port port, Probe probe) {
|
// private void createService(InfraHost infraHost, Port port, Probe probe) {
|
||||||
|
|
||||||
if(port.getServices() == null) {
|
// if(port.getServices() == null) {
|
||||||
return;
|
// return;
|
||||||
}
|
// }
|
||||||
|
|
||||||
MetaInfraType typeService = new MetaInfraType();
|
// MetaInfraType typeService = new MetaInfraType();
|
||||||
typeService.setId(7);
|
// typeService.setId(7);
|
||||||
|
|
||||||
String portType = "UDP";
|
// String portType = "UDP";
|
||||||
|
|
||||||
if(port.getPortType() == PortType.TLS || port.getPortType() == PortType.TCP) {
|
// if(port.getPortType() == PortType.TLS || port.getPortType() == PortType.TCP) {
|
||||||
portType = "TCP";
|
// portType = "TCP";
|
||||||
}
|
// }
|
||||||
|
|
||||||
for(com.loafle.overflow.module.discovery.model.Service service : port.getServices()) {
|
// for(com.loafle.overflow.module.discovery.model.Service service : port.getServices()) {
|
||||||
|
|
||||||
InfraService dbInfraService = this.infraServiceService.readByService(infraHost.getId(), port.getPortNumber(), portType);
|
// InfraService dbInfraService = this.infraServiceService.readByService(infraHost.getId(), port.getPortNumber(), portType);
|
||||||
|
|
||||||
if(dbInfraService != null) {
|
// if(dbInfraService != null) {
|
||||||
if(service.isTarget() && dbInfraService.getTarget() == null) {
|
// if(service.isTarget() && dbInfraService.getTarget() == null) {
|
||||||
Target targetService = new Target();
|
// Target targetService = new Target();
|
||||||
targetService.setDisplayName(service.getServiceName() + "-Service");
|
// targetService.setDisplayName(service.getServiceName() + "-Service");
|
||||||
this.targetService.regist(targetService);
|
// this.targetService.regist(targetService);
|
||||||
dbInfraService.setTarget(targetService);
|
// dbInfraService.setTarget(targetService);
|
||||||
this.infraServiceService.regist(dbInfraService);
|
// this.infraServiceService.regist(dbInfraService);
|
||||||
}
|
// }
|
||||||
continue;
|
// continue;
|
||||||
}
|
// }
|
||||||
|
|
||||||
InfraService infraService = new InfraService();
|
// InfraService infraService = new InfraService();
|
||||||
infraService.setHost(infraHost);
|
// infraService.setHost(infraHost);
|
||||||
infraService.setPort(port.getPortNumber());
|
// infraService.setPort(port.getPortNumber());
|
||||||
infraService.setPortType(portType);
|
// infraService.setPortType(portType);
|
||||||
infraService.setInfraType(typeService);
|
// infraService.setInfraType(typeService);
|
||||||
infraService.setProbe(probe);
|
// infraService.setProbe(probe);
|
||||||
|
|
||||||
if (port.getPortType() == PortType.TLS) {
|
// if (port.getPortType() == PortType.TLS) {
|
||||||
infraService.setTlsType(true);
|
// infraService.setTlsType(true);
|
||||||
}
|
// }
|
||||||
infraService.setVendor(MetaInfraVendor.CreateInfraVendorByService(service.getServiceName()));
|
// infraService.setVendor(MetaInfraVendor.CreateInfraVendorByService(service.getServiceName()));
|
||||||
|
|
||||||
if(service.isTarget()) {
|
// if(service.isTarget()) {
|
||||||
Target targetService = new Target();
|
// Target targetService = new Target();
|
||||||
targetService.setDisplayName(service.getServiceName() + "-Service");
|
// targetService.setDisplayName(service.getServiceName() + "-Service");
|
||||||
this.targetService.regist(targetService);
|
// this.targetService.regist(targetService);
|
||||||
infraService.setTarget(targetService);
|
// infraService.setTarget(targetService);
|
||||||
}
|
// }
|
||||||
|
|
||||||
this.infraServiceService.regist(infraService);
|
// this.infraServiceService.regist(infraService);
|
||||||
|
|
||||||
}
|
// }
|
||||||
|
|
||||||
}
|
// }
|
||||||
|
|
||||||
private void createPort(InfraHost infraHost, Host host, Probe probe) {
|
// private void createPort(InfraHost infraHost, Host host, Probe probe) {
|
||||||
|
|
||||||
if(host.getPorts() == null) {
|
// if(host.getPorts() == null) {
|
||||||
return;
|
// return;
|
||||||
}
|
// }
|
||||||
|
|
||||||
String portType = "UDP";
|
// String portType = "UDP";
|
||||||
|
|
||||||
MetaInfraType typePort = new MetaInfraType();
|
// MetaInfraType typePort = new MetaInfraType();
|
||||||
typePort.setId(6);
|
// typePort.setId(6);
|
||||||
|
|
||||||
InfraOS infraOS = infraHost.getOs();
|
// InfraOS infraOS = infraHost.getOs();
|
||||||
|
|
||||||
for(Port port : host.getPorts()) {
|
// for(Port port : host.getPorts()) {
|
||||||
|
|
||||||
if(port.getPortType() == PortType.TLS || port.getPortType() == PortType.TCP) {
|
// if(port.getPortType() == PortType.TLS || port.getPortType() == PortType.TCP) {
|
||||||
portType = "TCP";
|
// portType = "TCP";
|
||||||
}
|
// }
|
||||||
|
|
||||||
InfraOSPort dbInfraOSPort = this.infraOSPortService.readByPort(infraOS.getId(), port.getPortNumber(), portType);
|
// InfraOSPort dbInfraOSPort = this.infraOSPortService.readByPort(infraOS.getId(), port.getPortNumber(), portType);
|
||||||
if(dbInfraOSPort == null) {
|
// if(dbInfraOSPort == null) {
|
||||||
InfraOSPort infraOSPort = new InfraOSPort();
|
// InfraOSPort infraOSPort = new InfraOSPort();
|
||||||
infraOSPort.setOs(infraOS);
|
// infraOSPort.setOs(infraOS);
|
||||||
infraOSPort.setPort(port.getPortNumber());
|
// infraOSPort.setPort(port.getPortNumber());
|
||||||
infraOSPort.setPortType(portType);
|
// infraOSPort.setPortType(portType);
|
||||||
infraOSPort.setProbe(probe);
|
// infraOSPort.setProbe(probe);
|
||||||
infraOSPort.setInfraType(typePort);
|
// infraOSPort.setInfraType(typePort);
|
||||||
|
|
||||||
if (port.getPortType() == PortType.TLS) {
|
// if (port.getPortType() == PortType.TLS) {
|
||||||
infraOSPort.setTlsType(true);
|
// infraOSPort.setTlsType(true);
|
||||||
}
|
// }
|
||||||
infraOSPort.setVendor(MetaInfraVendor.CreateInfraVendorByPort(port.getPortNumber()));
|
// infraOSPort.setVendor(MetaInfraVendor.CreateInfraVendorByPort(port.getPortNumber()));
|
||||||
this.infraOSPortService.regist(infraOSPort);
|
// this.infraOSPortService.regist(infraOSPort);
|
||||||
}
|
// }
|
||||||
|
|
||||||
this.createService(infraHost, port, probe);
|
// this.createService(infraHost, port, probe);
|
||||||
}
|
// }
|
||||||
}
|
// }
|
||||||
|
|
||||||
private InfraHost createAndReadHost(Host host, Probe probe) {
|
// private InfraHost createAndReadHost(Host host, Probe probe) {
|
||||||
|
|
||||||
InfraHost infraHost = this.infraHostService.readByIp(host.getIp());
|
// InfraHost infraHost = this.infraHostService.readByIp(host.getIp());
|
||||||
if(infraHost != null) {
|
// if(infraHost != null) {
|
||||||
|
|
||||||
if(host.isTarget() && infraHost.getTarget() == null) {
|
// if(host.isTarget() && infraHost.getTarget() == null) {
|
||||||
Target target = new Target();
|
// Target target = new Target();
|
||||||
target.setDisplayName(String.valueOf(host.getIp()) + "-Host");
|
// target.setDisplayName(String.valueOf(host.getIp()) + "-Host");
|
||||||
|
|
||||||
this.targetService.regist(target);
|
// this.targetService.regist(target);
|
||||||
infraHost.setTarget(target);
|
// infraHost.setTarget(target);
|
||||||
this.infraHostService.regist(infraHost);
|
// this.infraHostService.regist(infraHost);
|
||||||
}
|
// }
|
||||||
|
|
||||||
return infraHost;
|
// return infraHost;
|
||||||
} else {
|
// } else {
|
||||||
MetaInfraType typeMachine = new MetaInfraType();
|
// MetaInfraType typeMachine = new MetaInfraType();
|
||||||
typeMachine.setId(1); // 1 = Machine;
|
// typeMachine.setId(1); // 1 = Machine;
|
||||||
|
|
||||||
MetaInfraType typeOS = new MetaInfraType();
|
// MetaInfraType typeOS = new MetaInfraType();
|
||||||
typeOS.setId(3); // 3 = Os
|
// typeOS.setId(3); // 3 = Os
|
||||||
|
|
||||||
MetaInfraType typeHost = new MetaInfraType();
|
// MetaInfraType typeHost = new MetaInfraType();
|
||||||
typeHost.setId(2); // 2 = Host
|
// typeHost.setId(2); // 2 = Host
|
||||||
|
|
||||||
InfraMachine infraMachine = new InfraMachine();
|
// InfraMachine infraMachine = new InfraMachine();
|
||||||
infraMachine.setProbe(probe);
|
// infraMachine.setProbe(probe);
|
||||||
infraMachine.setInfraType(typeMachine);
|
// infraMachine.setInfraType(typeMachine);
|
||||||
infraMachine.setMeta(StringConvertor.intToIp(host.getIp())+"-MACHINE");
|
// infraMachine.setMeta(StringConvertor.intToIp(host.getIp())+"-MACHINE");
|
||||||
this.infraMachineService.regist(infraMachine);
|
// this.infraMachineService.regist(infraMachine);
|
||||||
|
|
||||||
InfraOS infraOS = new InfraOS();
|
// InfraOS infraOS = new InfraOS();
|
||||||
infraOS.setMachine(infraMachine);
|
// infraOS.setMachine(infraMachine);
|
||||||
infraOS.setVendor(MetaInfraVendor.CreateInfraVendorByOS(host.getOs()));
|
// infraOS.setVendor(MetaInfraVendor.CreateInfraVendorByOS(host.getOs()));
|
||||||
infraOS.setInfraType(typeOS);
|
// infraOS.setInfraType(typeOS);
|
||||||
infraOS.setProbe(probe);
|
// infraOS.setProbe(probe);
|
||||||
infraOS.setMeta(StringConvertor.intToIp(host.getIp())+"-OS");
|
// infraOS.setMeta(StringConvertor.intToIp(host.getIp())+"-OS");
|
||||||
this.infraOSService.regist(infraOS);
|
// this.infraOSService.regist(infraOS);
|
||||||
|
|
||||||
InfraHost newInfraHost = new InfraHost();
|
// InfraHost newInfraHost = new InfraHost();
|
||||||
newInfraHost.setIp(host.getIp());
|
// newInfraHost.setIp(host.getIp());
|
||||||
newInfraHost.setMac(host.getMac());
|
// newInfraHost.setMac(host.getMac());
|
||||||
newInfraHost.setOs(infraOS);
|
// newInfraHost.setOs(infraOS);
|
||||||
newInfraHost.setInfraType(typeHost);
|
// newInfraHost.setInfraType(typeHost);
|
||||||
newInfraHost.setProbe(probe);
|
// newInfraHost.setProbe(probe);
|
||||||
|
|
||||||
if(host.isTarget()) {
|
// if(host.isTarget()) {
|
||||||
Target target = new Target();
|
// Target target = new Target();
|
||||||
target.setDisplayName(StringConvertor.intToIp(host.getIp()) + "-Host");
|
// target.setDisplayName(StringConvertor.intToIp(host.getIp()) + "-Host");
|
||||||
|
|
||||||
this.targetService.regist(target);
|
// this.targetService.regist(target);
|
||||||
newInfraHost.setTarget(target);
|
// newInfraHost.setTarget(target);
|
||||||
}
|
// }
|
||||||
|
|
||||||
this.infraHostService.regist(newInfraHost);
|
// this.infraHostService.regist(newInfraHost);
|
||||||
infraHost = newInfraHost;
|
// infraHost = newInfraHost;
|
||||||
}
|
// }
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
return infraHost;
|
// return infraHost;
|
||||||
}
|
// }
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -7,8 +7,8 @@ public class ProxyServerInterceptor implements ServerInterceptor {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public <ReqT, RespT> ServerCall.Listener<ReqT> interceptCall(ServerCall<ReqT, RespT> call, Metadata headers, ServerCallHandler<ReqT, RespT> next) {
|
public <ReqT, RespT> ServerCall.Listener<ReqT> interceptCall(ServerCall<ReqT, RespT> call, Metadata headers, ServerCallHandler<ReqT, RespT> next) {
|
||||||
String email = headers.get(SessionMetadata.METADATA_EMAIL_KEY);
|
String sessionID = headers.get(SessionMetadata.METADATA_SESSION_ID_KEY);
|
||||||
Context ctx = Context.current().withValue(SessionMetadata.CTX_EMAIL_KEY, email);
|
Context ctx = Context.current().withValue(SessionMetadata.CTX_SESSION_ID_KEY, sessionID);
|
||||||
|
|
||||||
return Contexts.interceptCall(ctx, call, headers, next);
|
return Contexts.interceptCall(ctx, call, headers, next);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue
Block a user