All Downloads are FREE. Search and download functionalities are using the official Maven repository.

net.i2p.router.networkdb.kademlia.FloodOnlyLookupMatchJob Maven / Gradle / Ivy

There is a newer version: 2.6.0
Show newest version
package net.i2p.router.networkdb.kademlia;

import net.i2p.data.DatabaseEntry;
import net.i2p.data.LeaseSet;
import net.i2p.data.i2np.DatabaseSearchReplyMessage;
import net.i2p.data.i2np.DatabaseStoreMessage;
import net.i2p.data.i2np.I2NPMessage;
import net.i2p.router.JobImpl;
import net.i2p.router.ReplyJob;
import net.i2p.router.RouterContext;
import net.i2p.util.Log;

class FloodOnlyLookupMatchJob extends JobImpl implements ReplyJob {
    protected final Log _log;
    protected final FloodSearchJob _search;
    protected volatile boolean _success;

    public FloodOnlyLookupMatchJob(RouterContext ctx, FloodSearchJob job) {
        super(ctx);
        _log = ctx.logManager().getLog(getClass());
        _search = job;
    }

    public void runJob() { 
        if (_success) {
            if (_log.shouldLog(Log.INFO))
                _log.info(_search.getJobId() + ": search match for " + _search.getKey());
            _search.success();
        } else {
            // In practice, we always have zero remaining when this is called,
            // because the selector only returns true when there is zero remaining
            if (_log.shouldLog(Log.INFO))
                _log.info(_search.getJobId() + ": search failed for " + _search.getKey());
            _search.failed();
        }
    }

    public String getName() { return "NetDb flood search match"; }

    public void setMessage(I2NPMessage message) {
        int mtype = message.getType();
        if (mtype == DatabaseSearchReplyMessage.MESSAGE_TYPE) {
            // DSRM processing now in FloodOnlyLookupSelector instead of here,
            // a dsrm is only passed in when there are no more lookups remaining
            // so that all DSRM's are processed, not just the last one.
            _search.failed();
            return;
        }
        if (mtype != DatabaseStoreMessage.MESSAGE_TYPE)
            return;

        DatabaseStoreMessage dsm = (DatabaseStoreMessage)message;
        if (_log.shouldDebug())
            _log.debug(_search.getJobId() + ": got a DSM for " 
                      + dsm.getKey().toBase64());
        // This store will handled by HFDSMJ.
        // Just note success here.
        if (dsm.getKey().equals(_search.getKey()))
            _success = true;
        DatabaseEntry entry = dsm.getEntry();
        int type = entry.getType();
        if (DatabaseEntry.isLeaseSet(type)) {
            // Since HFDSMJ wants to setReceivedAsPublished(), we have to
            // set a flag saying this was really the result of a query,
            // so don't do that.
            LeaseSet ls = (LeaseSet) dsm.getEntry();
            ls.setReceivedAsReply();
        }
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy