summaryrefslogtreecommitdiffstats
path: root/src/main/java/org/openslx/imagemaster/serverconnection/CRCScheduler.java
blob: c47eb0473d3bf0de4cb129bb0c424f1d20974749 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
package org.openslx.imagemaster.serverconnection;

import java.io.IOException;
import java.util.Iterator;
import java.util.List;
import java.util.Timer;
import java.util.TimerTask;

import org.apache.log4j.Logger;
import org.openslx.imagemaster.crcchecker.CRCChecker;

/**
 * Class to schedule crc checks.
 */
public class CRCScheduler extends TimerTask
{

	private static Logger log = Logger.getLogger( CRCScheduler.class );

	@Override
	public void run()
	{
		log.debug( "Starting checks..." );
		List<UploadingImage> list = ImageProcessor.getImagesToCheck();
		log.debug(list);
		Iterator<UploadingImage> iter = list.iterator();
		while ( iter.hasNext() ) {
			UploadingImage image = iter.next();
			log.debug( "Checking blocks of " + image.getDbImage().imageName );
			CRCChecker crcChecker = new CRCChecker( image.getImageFile(), image.getCrcFile() );
			log.debug( "CRCFile is valid: " + crcChecker.hasValidCrcFile() );
			for ( int block = 0; block < image.getNumberOfBlocks(); block++ ) {
				if ( image.needsCheck( block ) ) {
					try {
						if ( crcChecker.checkBlock( block ) ) {
							image.setValid( block );
							log.debug( block + " was valid" );
						} else {
							image.setNeedsRequest( block );
							log.debug( block + " was NOT valid" );
						}
					} catch ( IOException e ) {
						// TODO: Handle that crc file or image file could not be read.
						log.debug( "error" );
					}
				}
			}
			image.updateDb();
		}
		log.debug( "... done" );
	}

	public static void startScheduling()
	{
		Timer timer = new Timer( "CRCScheduler" );

		// start now and fire every 60 s
		//timer.schedule( new CRCScheduler(), 0, 60000L );

		timer.schedule( new CRCScheduler(), 0L, 30000L );
	}

}