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

com.aoindustries.aoserv.client.FailoverFileLog Maven / Gradle / Ivy

There is a newer version: 1.92.0
Show newest version
/*
 * aoserv-client - Java client for the AOServ platform.
 * Copyright (C) 2000-2013, 2016  AO Industries, Inc.
 *     [email protected]
 *     7262 Bull Pen Cir
 *     Mobile, AL 36695
 *
 * This file is part of aoserv-client.
 *
 * aoserv-client is free software: you can redistribute it and/or modify
 * it under the terms of the GNU Lesser General Public License as published by
 * the Free Software Foundation, either version 3 of the License, or
 * (at your option) any later version.
 *
 * aoserv-client 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 Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public License
 * along with aoserv-client.  If not, see .
 */
package com.aoindustries.aoserv.client;

import com.aoindustries.io.CompressedDataInputStream;
import com.aoindustries.io.CompressedDataOutputStream;
import java.io.IOException;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Timestamp;

/**
 * The entire contents of servers are periodically replicated to another server.  In the
 * event of hardware failure, this other server may be booted to take place of the
 * failed machine.  All transfers to the failover server are logged.
 *
 * @author  AO Industries, Inc.
 */
final public class FailoverFileLog extends AOServObject implements SingleTableObject {

	static final String COLUMN_REPLICATION_name = "replication";
	static final String COLUMN_END_TIME_name = "end_time";

	private AOServTable table;

	private int pkey;
	private int replication;
	private long startTime;
	private long endTime;
	private int scanned;
	private int updated;
	private long bytes;
	private boolean is_successful;

	@Override
	boolean equalsImpl(Object O) {
		return
			O instanceof FailoverFileLog
			&& ((FailoverFileLog)O).pkey==pkey
		;
	}

	public long getBytes() {
		return bytes;
	}

	@Override
	Object getColumnImpl(int i) {
		switch(i) {
			case 0: return pkey;
			case 1: return replication;
			case 2: return getStartTime();
			case 3: return getEndTime();
			case 4: return scanned;
			case 5: return updated;
			case 6: return bytes;
			case 7: return is_successful;
			default: throw new IllegalArgumentException("Invalid index: "+i);
		}
	}

	public Timestamp getStartTime() {
		return new Timestamp(startTime);
	}

	public Timestamp getEndTime() {
		return new Timestamp(endTime);
	}

	public int getPkey() {
		return pkey;
	}

	@Override
	public Integer getKey() {
		return pkey;
	}

	public int getScanned() {
		return scanned;
	}

	public FailoverFileReplication getFailoverFileReplication() throws SQLException, IOException {
		FailoverFileReplication ffr=table.connector.getFailoverFileReplications().get(replication);
		if(ffr==null) throw new SQLException("Unable to find FailoverFileReplication: "+replication);
		return ffr;
	}

	/**
	 * Gets the AOServTable that contains this AOServObject.
	 *
	 * @return  the AOServTable.
	 */
	@Override
	public AOServTable getTable() {
		return table;
	}

	@Override
	public SchemaTable.TableID getTableID() {
		return SchemaTable.TableID.FAILOVER_FILE_LOG;
	}

	public int getUpdated() {
		return updated;
	}

	@Override
	int hashCodeImpl() {
		return pkey;
	}

	@Override
	public void init(ResultSet result) throws SQLException {
		pkey=result.getInt(1);
		replication=result.getInt(2);
		startTime=result.getTimestamp(3).getTime();
		endTime=result.getTimestamp(4).getTime();
		scanned=result.getInt(5);
		updated=result.getInt(6);
		bytes=result.getLong(7);
		is_successful=result.getBoolean(8);
	}

	public boolean isSuccessful() {
		return is_successful;
	}

	@Override
	public void read(CompressedDataInputStream in) throws IOException {
		pkey=in.readCompressedInt();
		replication=in.readCompressedInt();
		startTime=in.readLong();
		endTime=in.readLong();
		scanned=in.readCompressedInt();
		updated=in.readCompressedInt();
		bytes=in.readLong();
		is_successful=in.readBoolean();
	}

	@Override
	public void setTable(AOServTable table) {
		if(this.table!=null) throw new IllegalStateException("table already set");
		this.table=table;
	}

	@Override
	public void write(CompressedDataOutputStream out, AOServProtocol.Version version) throws IOException {
		out.writeCompressedInt(pkey);
		out.writeCompressedInt(replication);
		out.writeLong(startTime);
		out.writeLong(endTime);
		out.writeCompressedInt(scanned);
		out.writeCompressedInt(updated);
		out.writeLong(bytes);
		out.writeBoolean(is_successful);
	}
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy