/* * RHQ Management Platform * Copyright (C) 2005-2011 Red Hat, Inc. * All rights reserved. * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License, version 2, as * published by the Free Software Foundation, and/or the GNU Lesser * General Public License, version 2.1, also as published by the Free * Software Foundation. * * This program 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 and the GNU Lesser General Public License * for more details. * * You should have received a copy of the GNU General Public License * and the GNU Lesser General Public License along with this program; * if not, write to the Free Software Foundation, Inc., * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */ package org.rhq.core.domain.common; import java.io.Serializable; import java.util.HashMap; /** * Provides simple strings to describe certain server details, useful for end users that have a need to see * this data. This is meant to be used as a read-only pojo to be shared to clients. * * Some of the fields in this pojo may be empty if the user didn't have permissions to see those fields. * * @author John Mazzitelli */ public class ServerDetails implements Serializable { private static final long serialVersionUID = 1L; public enum Detail { DATABASE_CONNECTION_URL, // DATABASE_PRODUCT_NAME, // DATABASE_PRODUCT_VERSION, // DATABASE_DRIVER_NAME, // DATABASE_DRIVER_VERSION, // SERVER_TIMEZONE, // SERVER_LOCAL_TIME, // SERVER_INSTALL_DIR, // where RHQ is installed, the top directory where everything else is SERVER_HOME_DIR, // where the RHQ server's JBossAS deployment is; this is under the install dir /** * @deprecated this is no longer used or exposed by the server. The measurements are not stored in the database * anymore. */ @Deprecated CURRENT_MEASUREMENT_TABLE, // /** * @deprecated this is no longer used or exposed by the server. The measurements are not stored in the database * anymore. */ @Deprecated NEXT_MEASUREMENT_TABLE_ROTATION, // SERVER_IDENTITY; }; private HashMap<Detail, String> details = new HashMap<Detail, String>(Detail.values().length); private ProductInfo productInfo; /** * @return information about the product itself (like its version). */ public ProductInfo getProductInfo() { return this.productInfo; } public void setProductInfo(ProductInfo info) { this.productInfo = info; } /** * Returns details about the server that returned this object. The keys are one of the * {@link Detail} enums. You are not guaranteed to have all details in the returned map; * if the user doesn't have the permissions necessary, some details will not be available. * @return HashMap of the details */ public HashMap<Detail, String> getDetails() { return this.details; } public void setDetails(HashMap<Detail, String> details) { this.details = details; } }