/**
* $RCSfile$
* $Revision: 7071 $
* $Date: 2007-02-11 18:59:05 -0600 (Sun, 11 Feb 2007) $
*
* Copyright 2003-2007 Jive Software.
*
* All rights reserved. Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.jivesoftware.smackx;
import java.util.ArrayList;
import java.util.Collections;
import java.util.Iterator;
import java.util.List;
import org.jivesoftware.smack.packet.Packet;
import org.jivesoftware.smack.packet.PacketExtension;
import org.jivesoftware.smackx.packet.DataForm;
/**
* Represents a set of data results returned as part of a search. The report is
* structured in columns and rows.
*
* @author Gaston Dombiak
*/
public class ReportedData {
/**
*
* Represents the columns definition of the reported data.
*
* @author Gaston Dombiak
*/
public static class Column {
private final String label;
private final String variable;
private final String type;
/**
* Creates a new column with the specified definition.
*
* @param label
* the columns's label.
* @param variable
* the variable name of the column.
* @param type
* the format for the returned data.
*/
public Column(String label, String variable, String type) {
this.label = label;
this.variable = variable;
this.type = type;
}
/**
* Returns the column's label.
*
* @return label of the column.
*/
public String getLabel() {
return label;
}
/**
* Returns the column's data format. Valid formats are:
*
* <ul>
* <li>text-single -> single line or word of text
* <li>text-private -> instead of showing the user what they typed, you
* show ***** to protect it
* <li>text-multi -> multiple lines of text entry
* <li>list-single -> given a list of choices, pick one
* <li>list-multi -> given a list of choices, pick one or more
* <li>boolean -> 0 or 1, true or false, yes or no. Default value is 0
* <li>fixed -> fixed for putting in text to show sections, or just
* advertise your web site in the middle of the form
* <li>hidden -> is not given to the user at all, but returned with the
* questionnaire
* <li>jid-single -> Jabber ID - choosing a JID from your roster, and
* entering one based on the rules for a JID.
* <li>jid-multi -> multiple entries for JIDs
* </ul>
*
* @return format for the returned data.
*/
public String getType() {
return type;
}
/**
* Returns the variable name that the column is showing.
*
* @return the variable name of the column.
*/
public String getVariable() {
return variable;
}
}
public static class Field {
private final String variable;
private final List<String> values;
public Field(String variable, List<String> values) {
this.variable = variable;
this.values = values;
}
/**
* Returns an iterator on the values reported as part of the search.
*
* @return the returned values of the search.
*/
public Iterator<String> getValues() {
return Collections.unmodifiableList(values).iterator();
}
/**
* Returns the variable name that the field represents.
*
* @return the variable name of the field.
*/
public String getVariable() {
return variable;
}
}
public static class Row {
private List<Field> fields = new ArrayList<Field>();
public Row(List<Field> fields) {
this.fields = fields;
}
/**
* Returns the fields that define the data that goes with the item.
*
* @return the fields that define the data that goes with the item.
*/
private Iterator<Field> getFields() {
return Collections.unmodifiableList(new ArrayList<Field>(fields))
.iterator();
}
/**
* Returns the values of the field whose variable matches the requested
* variable.
*
* @param variable
* the variable to match.
* @return the values of the field whose variable matches the requested
* variable.
*/
public Iterator<String> getValues(String variable) {
for (final Iterator<Field> it = getFields(); it.hasNext();) {
final Field field = it.next();
if (variable.equalsIgnoreCase(field.getVariable())) {
return field.getValues();
}
}
return null;
}
}
/**
* Returns a new ReportedData if the packet is used for reporting data and
* includes an extension that matches the elementName and namespace
* "x","jabber:x:data".
*
* @param packet
* the packet used for reporting data.
*/
public static ReportedData getReportedDataFrom(Packet packet) {
// Check if the packet includes the DataForm extension
final PacketExtension packetExtension = packet.getExtension("x",
"jabber:x:data");
if (packetExtension != null) {
// Check if the existing DataForm is a result of a search
final DataForm dataForm = (DataForm) packetExtension;
if (dataForm.getReportedData() != null) {
return new ReportedData(dataForm);
}
}
// Otherwise return null
return null;
}
private final List<Column> columns = new ArrayList<Column>();
private final List<Row> rows = new ArrayList<Row>();
private String title = "";
public ReportedData() {
// Allow for model creation of ReportedData.
}
/**
* Creates a new ReportedData based on the returned dataForm from a search
* (namespace "jabber:iq:search").
*
* @param dataForm
* the dataForm returned from a search (namespace
* "jabber:iq:search").
*/
private ReportedData(DataForm dataForm) {
// Add the columns to the report based on the reported data fields
for (final Iterator<?> fields = dataForm.getReportedData().getFields(); fields
.hasNext();) {
final FormField field = (FormField) fields.next();
columns.add(new Column(field.getLabel(), field.getVariable(), field
.getType()));
}
// Add the rows to the report based on the form's items
for (final Iterator<?> items = dataForm.getItems(); items.hasNext();) {
final DataForm.Item item = (DataForm.Item) items.next();
final List<Field> fieldList = new ArrayList<Field>(columns.size());
FormField field;
for (final Iterator<?> fields = item.getFields(); fields.hasNext();) {
field = (FormField) fields.next();
// The field is created with all the values of the data form's
// field
final List<String> values = new ArrayList<String>();
for (final Iterator<String> it = field.getValues(); it
.hasNext();) {
values.add(it.next());
}
fieldList.add(new Field(field.getVariable(), values));
}
rows.add(new Row(fieldList));
}
// Set the report's title
title = dataForm.getTitle();
}
/**
* Adds a new <code>Column</code>
*
* @param column
* the column to add.
*/
public void addColumn(Column column) {
columns.add(column);
}
/**
* Adds a new <code>Row</code>.
*
* @param row
* the new row to add.
*/
public void addRow(Row row) {
rows.add(row);
}
/**
* Returns an Iterator for the columns returned from a search.
*
* @return an Iterator for the columns returned from a search.
*/
public Iterator<Column> getColumns() {
return Collections.unmodifiableList(new ArrayList<Column>(columns))
.iterator();
}
/**
* Returns an Iterator for the rows returned from a search.
*
* @return an Iterator for the rows returned from a search.
*/
public Iterator<Row> getRows() {
return Collections.unmodifiableList(new ArrayList<Row>(rows))
.iterator();
}
/**
* Returns the report's title. It is similar to the title on a web page or
* an X window.
*
* @return title of the report.
*/
public String getTitle() {
return title;
}
}