Search in sources :

Example 1 with IndexInfo

use of net.runelite.cache.client.IndexInfo in project runelite by runelite.

the class CacheUpdater method update.

public void update() throws IOException, InvalidEndpointException, InvalidPortException, InterruptedException {
    int rsVersion = RuneLiteAPI.getRsVersion();
    try (Connection con = sql2o.beginTransaction()) {
        CacheDAO cacheDao = new CacheDAO();
        CacheEntry cache = cacheDao.findMostRecent(con);
        boolean created = false;
        if (cache == null) {
            created = true;
            cache = cacheDao.createCache(con, rsVersion, Instant.now());
        }
        CacheStorage storage = new CacheStorage(cache, cacheDao, con);
        Store store = new Store(storage);
        store.load();
        ExecutorService executor = Executors.newSingleThreadExecutor();
        CacheClient client = new CacheClient(store, rsVersion, (Archive archive, byte[] data) -> executor.submit(new CacheUploader(minioClient, minioBucket, archive, data)));
        client.connect();
        HandshakeResponseType result = client.handshake().join();
        if (result != HandshakeResponseType.RESPONSE_OK) {
            logger.warn("Out of date!");
            return;
        }
        List<IndexInfo> indexes = client.requestIndexes();
        List<IndexEntry> entries = cacheDao.findIndexesForCache(con, cache);
        if (!checkOutOfDate(indexes, entries)) {
            logger.info("All up to date.");
            return;
        }
        client.download();
        CacheEntry newCache = created ? cache : cacheDao.createCache(con, rsVersion, Instant.now());
        storage.setCacheEntry(newCache);
        store.save();
        // ensure objects are added to the store before they become
        // visible in the database
        executor.shutdown();
        while (!executor.awaitTermination(1, TimeUnit.SECONDS)) {
            logger.debug("Waiting for termination of executor...");
        }
        // commit database
        con.commit();
    }
}
Also used : CacheClient(net.runelite.cache.client.CacheClient) Archive(net.runelite.cache.fs.Archive) HandshakeResponseType(net.runelite.protocol.api.login.HandshakeResponseType) Connection(org.sql2o.Connection) Store(net.runelite.cache.fs.Store) IndexEntry(net.runelite.cache.updater.beans.IndexEntry) IndexInfo(net.runelite.cache.client.IndexInfo) CacheEntry(net.runelite.cache.updater.beans.CacheEntry) ExecutorService(java.util.concurrent.ExecutorService)

Example 2 with IndexInfo

use of net.runelite.cache.client.IndexInfo in project runelite by runelite.

the class CacheUpdater method checkOutOfDate.

private boolean checkOutOfDate(List<IndexInfo> indexes, List<IndexEntry> dbIndexes) {
    if (indexes.size() != dbIndexes.size()) {
        return true;
    }
    for (int i = 0; i < indexes.size(); ++i) {
        IndexInfo ii = indexes.get(i);
        IndexEntry ie = dbIndexes.get(i);
        if (ii.getId() != ie.getIndexId() || ii.getRevision() != ie.getRevision() || ii.getCrc() != ie.getCrc()) {
            return true;
        }
    }
    return false;
}
Also used : IndexEntry(net.runelite.cache.updater.beans.IndexEntry) IndexInfo(net.runelite.cache.client.IndexInfo)

Aggregations

IndexInfo (net.runelite.cache.client.IndexInfo)2 IndexEntry (net.runelite.cache.updater.beans.IndexEntry)2 ExecutorService (java.util.concurrent.ExecutorService)1 CacheClient (net.runelite.cache.client.CacheClient)1 Archive (net.runelite.cache.fs.Archive)1 Store (net.runelite.cache.fs.Store)1 CacheEntry (net.runelite.cache.updater.beans.CacheEntry)1 HandshakeResponseType (net.runelite.protocol.api.login.HandshakeResponseType)1 Connection (org.sql2o.Connection)1