Search in sources :

Example 1 with CacheEntry

use of net.runelite.cache.updater.beans.CacheEntry 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 CacheEntry

use of net.runelite.cache.updater.beans.CacheEntry in project runelite by runelite.

the class CacheDAO method createCache.

public CacheEntry createCache(Connection con, int revision, Instant date) {
    int cacheId = con.createQuery("insert into cache (revision, date) values (:revision, :date)").addParameter("revision", revision).addParameter("date", date).executeUpdate().getKey(int.class);
    CacheEntry entry = new CacheEntry();
    entry.setId(cacheId);
    entry.setRevision(revision);
    entry.setDate(date);
    return entry;
}
Also used : CacheEntry(net.runelite.cache.updater.beans.CacheEntry)

Aggregations

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