package org.freertr.serv; import java.util.List; import org.freertr.addr.addrIP; import org.freertr.cfg.cfgAll; import org.freertr.cfg.cfgBrdg; import org.freertr.clnt.clntEtherIp; import org.freertr.ip.ipFwdIface; import org.freertr.ip.ipPrt; import org.freertr.pack.packHolder; import org.freertr.pipe.pipeSide; import org.freertr.prt.prtGenConn; import org.freertr.tab.tabGen; import org.freertr.user.userFilter; import org.freertr.user.userFormat; import org.freertr.user.userHelping; import org.freertr.util.bits; import org.freertr.util.cmds; import org.freertr.util.counter; import org.freertr.util.state; /** * etherip (rfc3378) server * * @author matecsaba */ public class servEtherIp extends servGeneric implements ipPrt { /** * create instance */ public servEtherIp() { } /** * interface to use */ public cfgBrdg brdgIfc; /** * sending ttl value, -1 means maps out */ public int sendingTTL = 255; /** * sending tos value, -1 means maps out */ public int sendingTOS = -1; /** * sending df value, -1 means maps out */ public int sendingDFN = -1; /** * sending flow value, -1 means maps out */ public int sendingFLW = -1; /** * physical interface */ public boolean physInt = false; /** * list of connections */ public tabGen conns = new tabGen(); /** * timeout */ public int timeout = 60000; /** * counter */ public counter cntr; /** * defaults text */ public final static String[] defaultL = { "server etherip .*!" + cmds.tabulator + "port " + clntEtherIp.prot, "server etherip .*!" + cmds.tabulator + "protocol " + proto2string(protoAllDgrm), "server etherip .*!" + cmds.tabulator + cmds.negated + cmds.tabulator + "physical-interface", "server etherip .*!" + cmds.tabulator + "timeout 60000" }; /** * defaults filter */ public static tabGen defaultF; public tabGen srvDefFlt() { return defaultF; } public void srvShRun(String beg, List l, int filter) { if (brdgIfc == null) { l.add(beg + "no bridge"); } else { l.add(beg + "bridge " + brdgIfc.number); } cmds.cfgLine(l, !physInt, beg, "physical-interface", ""); l.add(beg + "timeout " + timeout); } public boolean srvCfgStr(cmds cmd) { String s = cmd.word(); if (s.equals("timeout")) { timeout = bits.str2num(cmd.word()); return false; } if (s.equals("bridge")) { brdgIfc = cfgAll.brdgFind(cmd.word(), false); if (brdgIfc == null) { cmd.error("no such bridge group"); return false; } return false; } if (s.equals("physical-interface")) { physInt = true; return false; } if (!s.equals(cmds.negated)) { return true; } s = cmd.word(); if (s.equals("bridge")) { brdgIfc = null; return false; } if (s.equals("physical-interface")) { physInt = false; return false; } return true; } public void srvHelp(userHelping l) { l.add(null, "1 2 bridge set interface to clone"); l.add(null, "2 . number of bridge"); l.add(null, "1 2 timeout timeout of client"); l.add(null, "2 . milliseconds"); l.add(null, "1 . physical-interface adding as physical to bridge"); } public String srvName() { return "etherip"; } public int srvPort() { return clntEtherIp.prot; } public int srvProto() { return protoAllDgrm; } public boolean srvInit() { return genRawStart(this, 0); } public boolean srvDeinit() { return genRawStop(this, 0); } public boolean srvAccept(pipeSide pipe, prtGenConn id) { return true; } /** * get protocol number * * @return number */ public int getProtoNum() { return clntEtherIp.prot; } public String toString() { return "etherip"; } /** * close interface * * @param iface interface */ public void closeUp(ipFwdIface iface) { } /** * set state * * @param iface interface * @param stat state */ public void setState(ipFwdIface iface, state.states stat) { } /** * received packet * * @param rxIfc interface * @param pck packet */ public void recvPack(ipFwdIface rxIfc, packHolder pck) { servEtherIpConn ntry = new servEtherIpConn(rxIfc, pck.IPsrc, this); servEtherIpConn old = conns.add(ntry); if (old != null) { old.doRecv(pck); return; } if (brdgIfc == null) { return; } ntry.doStartup(); ntry.doRecv(pck); } /** * alert packet * * @param rxIfc interface * @param pck packet * @return false on success, true on error */ public boolean alertPack(ipFwdIface rxIfc, packHolder pck) { return true; } /** * error packet * * @param err error code * @param rtr address * @param rxIfc interface * @param pck packet */ public void errorPack(counter.reasons err, addrIP rtr, ipFwdIface rxIfc, packHolder pck) { } /** * get counter * * @return counter */ public counter getCounter() { return cntr; } /** * get show * * @return result */ public userFormat getShow() { userFormat res = new userFormat("|", "addr|iface|for|since"); for (int i = 0; i < conns.size(); i++) { servEtherIpConn ntry = conns.get(i); if (ntry == null) { continue; } res.add(ntry.peer + "|" + ntry.brdgIfc.getIfcName() + "|" + bits.timePast(ntry.created) + "|" + bits.time2str(cfgAll.timeZoneName, ntry.created + cfgAll.timeServerOffset, 3)); } return res; } /** * do clear * * @param peer peer ip */ public void doClear(addrIP peer) { for (int i = 0; i < conns.size(); i++) { servEtherIpConn ntry = conns.get(i); if (ntry == null) { continue; } if (peer.compareTo(ntry.peer) != 0) { continue; } ntry.doStop(); } } }