/* * RHQ Management Platform * Copyright (C) 2005-2012 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 as published by * the Free Software Foundation version 2 of the License. * * 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 for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */ package org.rhq.coregui.client.admin.topology; import static org.rhq.coregui.client.admin.topology.ServerDatasourceField.FIELD_ADDRESS; import static org.rhq.coregui.client.admin.topology.ServerDatasourceField.FIELD_AFFINITY_GROUP; import static org.rhq.coregui.client.admin.topology.ServerDatasourceField.FIELD_AFFINITY_GROUP_ID; import static org.rhq.coregui.client.admin.topology.ServerDatasourceField.FIELD_ID; import static org.rhq.coregui.client.admin.topology.ServerDatasourceField.FIELD_MTIME; import static org.rhq.coregui.client.admin.topology.ServerDatasourceField.FIELD_NAME; import static org.rhq.coregui.client.admin.topology.ServerDatasourceField.FIELD_OPERATION_MODE; import static org.rhq.coregui.client.admin.topology.ServerDatasourceField.FIELD_PORT; import static org.rhq.coregui.client.admin.topology.ServerDatasourceField.FIELD_SECURE_PORT; import java.util.ArrayList; import java.util.List; import com.google.gwt.user.client.rpc.AsyncCallback; import com.smartgwt.client.data.DSRequest; import com.smartgwt.client.data.DSResponse; import com.smartgwt.client.data.DataSourceField; import com.smartgwt.client.data.Record; import com.smartgwt.client.data.fields.DataSourceIntegerField; import com.smartgwt.client.widgets.grid.ListGridField; import com.smartgwt.client.widgets.grid.ListGridRecord; import org.rhq.core.domain.cloud.Server; import org.rhq.core.domain.cloud.Server.OperationMode; import org.rhq.core.domain.criteria.ServerCriteria; import org.rhq.core.domain.util.PageControl; import org.rhq.core.domain.util.PageList; import org.rhq.core.domain.util.PageOrdering; import org.rhq.coregui.client.CoreGUI; import org.rhq.coregui.client.components.table.TimestampCellFormatter; import org.rhq.coregui.client.gwt.GWTServiceLookup; import org.rhq.coregui.client.util.Log; /** * Datasource for @see Server. * * @author Jirka Kremser */ public class ServerDatasource extends AbstractServerNodeDatasource<Server, ServerCriteria> { // filters public static final String FILTER_ADDRESS = FIELD_ADDRESS.propertyName(); public static final String FILTER_PORT = FIELD_PORT.propertyName(); public static final String FILTER_SECURE_PORT = FIELD_SECURE_PORT.propertyName(); public static final String FILTER_OPERATION_MODE = FIELD_OPERATION_MODE.propertyName(); public static final String FILTER_COMPUTE_POWER = "computePower"; public static final String FILTER_AFFINITY_GROUP_ID = "affinityGroupId"; private final Integer affinityGroupId; public ServerDatasource(Integer affinityGroupId) { super(); this.affinityGroupId = affinityGroupId; List<DataSourceField> fields = addDataSourceFields(); addFields(fields); } @Override protected List<DataSourceField> addDataSourceFields() { List<DataSourceField> fields = super.addDataSourceFields(); DataSourceField idField = new DataSourceIntegerField(FIELD_ID.propertyName(), FIELD_ID.title(), 50); idField.setPrimaryKey(true); idField.setHidden(true); fields.add(idField); return fields; } public List<ListGridField> getListGridFields() { List<ListGridField> fields = new ArrayList<ListGridField>(); ListGridField idField = FIELD_ID.getListGridField(); idField.setHidden(true); fields.add(idField); fields.add(FIELD_NAME.getListGridField("*")); fields.add(FIELD_OPERATION_MODE.getListGridField("90")); fields.add(FIELD_ADDRESS.getListGridField("190")); fields.add(FIELD_PORT.getListGridField("90")); fields.add(FIELD_SECURE_PORT.getListGridField("75")); ListGridField lastUpdateTimeField = FIELD_MTIME.getListGridField("120"); TimestampCellFormatter.prepareDateField(lastUpdateTimeField); fields.add(lastUpdateTimeField); ListGridField affinityGroupIdField = FIELD_AFFINITY_GROUP_ID.getListGridField(); affinityGroupIdField.setHidden(true); fields.add(affinityGroupIdField); return fields; } @Override protected void executeFetch(final DSRequest request, final DSResponse response, ServerCriteria criteria) { if (criteria == null) { response.setTotalRows(0); processResponse(request.getRequestId(), response); return; } if (affinityGroupId != null) { criteria.addFilterAffinityGroupId(affinityGroupId); } GWTServiceLookup.getTopologyService().findServersByCriteria(criteria, new AsyncCallback<PageList<Server>>() { public void onSuccess(PageList<Server> result) { response.setData(buildRecords(result)); setPagingInfo(response, result); processResponse(request.getRequestId(), response); } public void onFailure(Throwable t) { CoreGUI.getErrorHandler().handleError(MSG.view_adminTopology_message_fetchServers2Fail(), t); response.setStatus(DSResponse.STATUS_FAILURE); processResponse(request.getRequestId(), response); } }); } /** * Returns a prepopulated PageControl based on the provided DSRequest. This will set sort fields, * pagination, but *not* filter fields. * * @param request the request to turn into a page control * @return the page control for passing to criteria and other queries */ @Override protected PageControl getPageControl(DSRequest request) { // Initialize paging. PageControl pageControl = new PageControl(0, getDataPageSize()); // Initialize sorting. String sortBy = request.getAttribute("sortBy"); if (sortBy != null) { String[] sorts = sortBy.split(","); for (String sort : sorts) { PageOrdering ordering = (sort.startsWith("-")) ? PageOrdering.DESC : PageOrdering.ASC; String columnName = (ordering == PageOrdering.DESC) ? sort.substring(1) : sort; pageControl.addDefaultOrderingField(columnName, ordering); } } return pageControl; } @Override public Server copyValues(Record from) { throw new UnsupportedOperationException("ServerDatasource.copyValues(Record from)"); } @Override public ListGridRecord copyValues(Server from) { ListGridRecord record = new ListGridRecord(); record.setAttribute(FIELD_ID.propertyName(), from.getId()); record.setAttribute(FIELD_NAME.propertyName(), from.getName()); record.setAttribute(FIELD_OPERATION_MODE.propertyName(), from.getOperationMode()); record.setAttribute(FIELD_ADDRESS.propertyName(), from.getAddress()); record.setAttribute(FIELD_PORT.propertyName(), from.getPort()); record.setAttribute(FIELD_SECURE_PORT.propertyName(), from.getSecurePort()); record.setAttribute(FIELD_MTIME.propertyName(), from.getMtime()); record.setAttribute(FIELD_AFFINITY_GROUP.propertyName(), from.getAffinityGroup() == null ? "" : from .getAffinityGroup().getName()); record.setAttribute(FIELD_AFFINITY_GROUP_ID.propertyName(), from.getAffinityGroup() == null ? "" : from .getAffinityGroup().getId()); return record; } @Override protected ServerCriteria getFetchCriteria(DSRequest request) { OperationMode[] modesFilter = getArrayFilter(request, FILTER_OPERATION_MODE, OperationMode.class); if (modesFilter == null || modesFilter.length == 0) { return null; // user didn't select any modes - return null to indicate no data should be displayed } ServerCriteria criteria = new ServerCriteria(); // printRequestCriteria(request); criteria.addFilterId(getFilter(request, FIELD_ID.propertyName(), Integer.class)); criteria.addFilterName(getFilter(request, FIELD_NAME.propertyName(), String.class)); criteria.addFilterAddress(getFilter(request, FILTER_ADDRESS, String.class)); criteria.addFilterPort(getFilter(request, FILTER_PORT, Integer.class)); criteria.addFilterSecurePort(getFilter(request, FILTER_SECURE_PORT, Integer.class)); criteria.addFilterOperationMode(modesFilter); criteria.addFilterComputePower(getFilter(request, FILTER_COMPUTE_POWER, Integer.class)); criteria.addFilterAffinityGroupId(getFilter(request, FILTER_AFFINITY_GROUP_ID, Integer.class)); //@todo: Remove me when finished debugging search expression Log.debug(" *** ServerCriteria Search String: " + getFilter(request, "search", String.class)); criteria.setSearchExpression(getFilter(request, "search", String.class)); return criteria; } }