/*
* This file is part of Fim - File Integrity Manager
*
* Copyright (C) 2017 Etienne Vrignaud
*
* Fim is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* Fim is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with Fim. If not, see <http://www.gnu.org/licenses/>.
*/
package org.fim.internal.hash;
import org.fim.model.Context;
import org.fim.model.HashMode;
import org.fim.model.Range;
import org.fim.util.HashModeUtil;
import java.nio.ByteBuffer;
import java.security.NoSuchAlgorithmException;
import static java.lang.Math.min;
import static org.fim.model.Constants._1_MB;
import static org.fim.model.HashMode.hashAll;
public class FullHasher extends AbstractHasher {
public static final int BLOCK_SIZE = 30 * _1_MB;
private long fileSize;
public FullHasher(Context context) throws NoSuchAlgorithmException {
super(context);
}
@Override
protected boolean isCompatible(HashMode hashMode) {
return HashModeUtil.isCompatible(hashMode, hashAll);
}
@Override
public void reset(long fileSize) {
super.reset(fileSize);
if (isActive()) {
this.fileSize = fileSize;
}
}
@Override
public Range getNextRange(long filePosition) {
long from = filePosition;
long to = min(fileSize, filePosition + BLOCK_SIZE);
return new Range(from, to);
}
@Override
protected ByteBuffer getNextBlockToHash(long filePosition, long currentPosition, ByteBuffer buffer) {
return buffer;
}
@Override
public boolean hashComplete() {
if (isActive()) {
return getBytesHashed() == fileSize;
} else {
return true;
}
}
}