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

com.aoindustries.aoserv.client.infrastructure.PhysicalServer Maven / Gradle / Ivy

There is a newer version: 1.92.0
Show newest version
/*
 * aoserv-client - Java client for the AOServ Platform.
 * Copyright (C) 2008-2013, 2016, 2017, 2018, 2019  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.infrastructure;

import com.aoindustries.aoserv.client.CachedObjectIntegerKey;
import com.aoindustries.aoserv.client.net.Host;
import com.aoindustries.aoserv.client.schema.AoservProtocol;
import com.aoindustries.aoserv.client.schema.Table;
import com.aoindustries.io.stream.StreamableInput;
import com.aoindustries.io.stream.StreamableOutput;
import com.aoindustries.util.InternUtils;
import java.io.IOException;
import java.sql.ResultSet;
import java.sql.SQLException;

/**
 * A PhysicalServer consumes space and electricity in a rack
 * and provides resources.
 *
 * @author  AO Industries, Inc.
 */
final public class PhysicalServer extends CachedObjectIntegerKey {

	static final int COLUMN_SERVER = 0;

	static final String COLUMN_SERVER_name = "server";

	private int rack;
	private short rackUnits;
	private int ram;
	private String processorType;
	private int processorSpeed;
	private int processorCores;
	private float maxPower;
	private Boolean supports_hvm;

	// Matches aoserv-master-db/aoindustries/infrastructure/PhysicalServer.UpsType-type.sql
	public enum UpsType {
		/**
		 * No UPS is supporting this device.
		 */
		none,

		/**
		 * The UPS is provided by the datacenter, but cannot be monitored for clean shutdown.
		 */
		datacenter,

		/**
		 * The UPS is an APC model and can be monitored for clean shutdown.
		 */
		apc
	}

	private UpsType upsType;

	@Override
	protected Object getColumnImpl(int i) {
		switch(i) {
			case COLUMN_SERVER: return pkey;
			case 1: return rack==-1 ? null : rack;
			case 2: return rackUnits==-1 ? null : rackUnits;
			case 3: return ram==-1 ? null : ram;
			case 4: return processorType;
			case 5: return processorSpeed==-1 ? null : processorSpeed;
			case 6: return processorCores==-1 ? null : processorCores;
			case 7: return Float.isNaN(maxPower) ? null : maxPower;
			case 8: return supports_hvm;
			case 9: return upsType.name();
			default: throw new IllegalArgumentException("Invalid index: " + i);
		}
	}

	public Host getHost() throws SQLException, IOException {
		Host se=table.getConnector().getNet().getHost().get(pkey);
		if(se==null) throw new SQLException("Unable to find Host: "+pkey);
		return se;
	}

	/**
	 * Gets the rack this server is part of or {@code null} if not in a rack.
	 */
	public Rack getRack() throws SQLException, IOException {
		if(rack==-1) return null;
		Rack ra = table.getConnector().getInfrastructure().getRack().get(rack);
		if(ra==null) throw new SQLException("Unable to find Rack: "+rack);
		return ra;
	}

	/**
	 * Gets the number of rack units used by this server or -1 if unknown
	 * or not applicable.
	 */
	public short getRackUnits() {
		return rackUnits;
	}

	/**
	 * Gets the number of megabytes of RAM in this server or -1 if not applicable.
	 */
	public int getRam() {
		return ram;
	}

	/**
	 * Gets the processor type or {@code null} if not applicable.
	 */
	public ProcessorType getProcessorType() throws SQLException, IOException {
		if(processorType==null) return null;
		ProcessorType pt = table.getConnector().getInfrastructure().getProcessorType().get(processorType);
		if(pt==null) throw new SQLException("Unable to find ProcessorType: "+processorType);
		return pt;
	}

	/**
	 * Gets the processor speed in MHz or -1 if not applicable.
	 */
	public int getProcessorSpeed() {
		return processorSpeed;
	}

	/**
	 * Gets the total number of processor cores or -1 if not applicable,
	 * different hyperthreads are counted as separate cores.
	 */
	public int getProcessorCores() {
		return processorCores;
	}

	/**
	 * Gets the maximum electricity current or Float.NaN if not known.
	 */
	public float getMaxPower() {
		return maxPower;
	}

	/**
	 * Gets if this supports HVM or {@code null} if not applicable.
	 */
	public Boolean getSupportsHvm() {
		return supports_hvm;
	}

	/**
	 * Gets the UPS type powering this server.
	 */
	public UpsType getUpsType() {
		return upsType;
	}

	@Override
	public Table.TableID getTableID() {
		return Table.TableID.PHYSICAL_SERVERS;
	}

	@Override
	public void init(ResultSet result) throws SQLException {
		int pos = 1;
		pkey = result.getInt(pos++);
		rack = result.getInt(pos++);
		if(result.wasNull()) rack = -1;
		rackUnits = result.getShort(pos++);
		if(result.wasNull()) rackUnits = -1;
		ram = result.getInt(pos++);
		if(result.wasNull()) ram = -1;
		processorType = result.getString(pos++);
		processorSpeed = result.getInt(pos++);
		if(result.wasNull()) processorSpeed = -1;
		processorCores = result.getInt(pos++);
		if(result.wasNull()) processorCores = -1;
		maxPower = result.getFloat(pos++);
		if(result.wasNull()) maxPower = Float.NaN;
		supports_hvm = result.getBoolean(pos++);
		if(result.wasNull()) supports_hvm = null;
		upsType = UpsType.valueOf(result.getString(pos++));
	}

	@Override
	public void read(StreamableInput in, AoservProtocol.Version protocolVersion) throws IOException {
		pkey = in.readCompressedInt();
		rack = in.readCompressedInt();
		rackUnits = in.readShort();
		ram = in.readCompressedInt();
		processorType = InternUtils.intern(in.readNullUTF());
		processorSpeed = in.readCompressedInt();
		processorCores = in.readCompressedInt();
		maxPower = in.readFloat();
		supports_hvm = in.readBoolean() ? in.readBoolean() : null;
		upsType = UpsType.valueOf(in.readUTF());
	}

	@Override
	public String toStringImpl() throws SQLException, IOException {
		return getHost().toStringImpl();
	}

	@Override
	public void write(StreamableOutput out, AoservProtocol.Version protocolVersion) throws IOException {
		out.writeCompressedInt(pkey);
		out.writeCompressedInt(rack);
		out.writeShort(rackUnits);
		out.writeCompressedInt(ram);
		out.writeNullUTF(processorType);
		out.writeCompressedInt(processorSpeed);
		out.writeCompressedInt(processorCores);
		out.writeFloat(maxPower);
		if(protocolVersion.compareTo(AoservProtocol.Version.VERSION_1_37)>=0) {
			out.writeBoolean(supports_hvm!=null);
			if(supports_hvm!=null) out.writeBoolean(supports_hvm);
		}
		if(protocolVersion.compareTo(AoservProtocol.Version.VERSION_1_63)>=0) out.writeUTF(upsType.name());
	}
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy