/* * Copyright (C) 2009-2017 Alistair Neil * * 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; either version 2 * of the License, or (at your option) any later version. * * 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ package client; import java.util.ArrayList; import java.util.Collections; import java.util.List; import javax.swing.table.DefaultTableModel; /** * * @author Alistair Neil */ public class GuardNodeTableModel extends DefaultTableModel { private final List salFinger = Collections.synchronizedList(new ArrayList()); private final String[] columnNames = {"GuardNode", "Country", "BW (MB\\s)", "Trusted"}; private NodeItem ni; private int enabledcount; public GuardNodeTableModel() { } public int getEnabledCount() { return enabledcount; } /** * Clear the table model of all data */ public void clear() { getDataVector().clear(); salFinger.clear(); enabledcount = 0; } /** * Get the number of columns * * @return columns as integer */ @Override public int getColumnCount() { return columnNames.length; } /** * Test if the cell is editable * * @param row Cell row * @param col Cell column * @return True if editable */ @Override public boolean isCellEditable(int row, int col) { return col == 3; } /** * Set value with given fingerprint at given column * * @param value Value * @param finger Fingerprint * @param col Column */ public void setValueAt(Object value, String finger, int col) { setValueAt(value, salFinger.indexOf(finger), col); } /** * Set cell value at row,col * * @param value * @param row * @param col */ @Override public void setValueAt(Object value, int row, int col) { try { ni = (NodeItem) super.getValueAt(row, 0); if (col == 3) { ni.setGuardEnabled((Boolean) value); if (ni.isGuardEnabled()) { enabledcount++; } else { if (enabledcount > 0) { enabledcount--; } } fireTableCellUpdated(row, col); } } catch (Exception ex) { } } /** * Get cell value as object at row,col * * @param row * @param col * @return value as object */ @Override public Object getValueAt(int row, int col) { ni = (NodeItem) super.getValueAt(row, 0); Object obj = null; switch (col) { case 0: obj = ni.getNickName(); break; case 1: obj = ni.getCountryName(); break; case 2: obj = ni.getBandwidth(); break; case 3: obj = ni.isGuardEnabled(); break; case 4: obj = ni.getFingerprint(); break; } return obj; } /** * Add rowdata with given data object array * * @param rowData */ @Override public void addRow(Object[] rowData) { super.addRow(rowData); ni = (NodeItem) rowData[0]; if (ni.isGuardEnabled()) { enabledcount++; } salFinger.add(ni.getFingerprint()); } /** * Get column name at given index * * @param index * @return name as string */ @Override public String getColumnName(int index) { return columnNames[index]; } /** * Set the column name at the specified index * * @param name * @param index */ public void setColumnName(String name, int index) { if (index < columnNames.length) { columnNames[index] = name; } } /** * Get column class at given index * * @param index * @return Class */ @Override public Class getColumnClass(int index) { Class cl; switch (index) { case 2: cl = Float.class; break; case 3: cl = Boolean.class; break; default: cl = String.class; break; } return cl; } }